当前位置: 首页 > article >正文

面试篇算法:(一:排序算法)

一:冒泡排序

int[] a={2,5,3,7,4,8}

for(i=0;i<a.length;i++)
{
	for(j=0;j<a.length-i-1;j++)
	{
		if(a[j]>a[j+1])
		(
			int temp=a[j];
			a[j]=a[j+1];
			a[j+1]=temp;
		)
	}
}

原理:进行多次的比较,每次将最大的值选取出来,放在最后面。在进行多次比较。直至结果出来。

二:插入排序

int a[]={2,5,3,7,4,8};

for(i=1;i<a.length;i++)
(
	for(j=i;j>0;j--)
	(
		if (a[j]>a[j-1])
		{
			int t=a[j];
			a[j]=a[j-1];
			a[j-1]=t;
		}
		else
		{break;}
	)
)
思路:从第二个开始选择,和前一个进行比较,选择出合适他的位置,然后多次进行排序,得到最终的结果。

三:选择排序

int[] a={2,5,3,7,4,8}

for(i=0;i<a.length;i++)
{
	int k=i;
	for(j=k+1;j<=a.length-1-i;j++)
	{
		if(a[j]>a[k])
		k=j;
	}
	int temp=a[j];
	a[j]=a[k];
	a[k]=tmep;
}
原理:每次排序的时候,默认第一个为最大的值,然后和后面的进行相继比较。直到选出最大的那个值。然后将最大的值和本次比较的最后一个值进行替换,来选出本次最大的值。

四:快速排序

public class kuaipai{
public static paixu(int[] array,int low,int high)
	{
		int i,j,amy,t;
		if (low>high)
		{return;}
		i=low;
		j=high;
		amy=array[i];
		
		while(i<j)
			{
				if(array[j]>amy) else j--;

				if(array[i]<amy) else i++;
				
				t=array[j];
				array[j]=array[i];
				array[i]=t;
			}
		t=array[low];
		array[low]=array[i];
		array[i]=t;
		
		paixu( array, low, i-1);
		paixu( array, i+1,high);
	}
public satic void main(string[] args)
	{
		int array[]={2,5,3,7,4,8};
		paixu(array,0,a.length-1);
		for(i=0;i<a.length;1++)
		{
			system.out.print(array[i]);
		}
	}
}
思路:先分开,在进行左右对比,进行调换位置。

五:归并排序

public void mergeSort(int [] nums){
        mergeSortInternal(nums, 0, nums.length - 1);
    }

    public void mergeSortInternal(int[] nums, int start, int end){
        if(start >= end){
            return;
        }
        int mid = (start + end) / 2;
        mergeSortInternal(nums, start, mid);
        mergeSortInternal(nums, mid + 1, end);

        merge(nums, start, mid, end);
    }

    public void merge(int[] nums, int start, int mid, int end){
        int[] res = new int[end - start + 1];
        int i = start;
        int j = mid + 1;
        int index = 0;

        while(i <= mid && j <= end){
            if(nums[i] < nums[j]){
                res[index++] = nums[i++]; 
            }else{
                res[index++] = nums[j++];
            }
        }
        while(i <= mid){
            res[index++] = nums[i++];
        }
        while(j <= end){
            res[index++] = nums[j++];
        }

        for(int k = 0; k < res.length; k++){
            nums[start + k] = res[k];
        }
    }
    思路:先分开在合并。

http://www.kler.cn/a/155647.html

相关文章:

  • 【大数据测试HBase数据库 — 详细教程(含实例与监控调优)】
  • 用vscode编写verilog时,如何有信号定义提示、信号定义跳转(go to definition)、模块跳转这些功能
  • AI 写作(五)核心技术之文本摘要:分类与应用(5/10)
  • 基于yolov8、yolov5的番茄成熟度检测识别系统(含UI界面、训练好的模型、Python代码、数据集)
  • 解决 Redis 报错:`(error) NOAUTH Authentication required`
  • 24/11/12 算法笔记<强化学习> Policy Gradient策略梯度
  • bean依赖属性配置
  • 常见的攻击防护
  • 正是阶段高等数学复习--函数极限的计算
  • Javaweb之Vue组件库Element案例异步数据加载的详细解析
  • HelpLook可以作为wordpress的替代品,帮助企业快速搭建博客
  • pikachu靶场:php反序列化漏洞
  • Mac下更新python
  • 后端Long型数据传到前端js后精度丢失的问题
  • 02.PostgreSQL 查询处理期间发生了什么?
  • 单片机学习11——矩阵键盘
  • 【无标题】我们只能用成功来摧毁我们,原来的自己只会破败自己的事情。
  • redis实现消息延迟队列
  • 使用Redis构建任务队列
  • Hdoop学习笔记(HDP)-Part.02 核心组件原理
  • 基于SSM的职业高中智慧作业试题系统设计
  • 3dMax拼图生成工具Puzzle2D使用教程
  • Java Throwable
  • Spring中@Transactional注解
  • QueryRunner报红处理
  • electron-vue运用及案例代码