这4个算法真的堪称经典,里面包含了许多数学思想,面试的时候也经常被问到。排序的话面试官一般会问你最熟悉的一种排序深入点的会问这几种排序的依据,二分查找更为重要,比起排序查找算是比较简单的了。下面我自己整理了一些东西和大家分享,说来惭愧以前就只会冒泡排序这么一种,废话不说了下面开始了。
1.最容易理解的排序【冒泡排序】
简单的说就是一次一次的交换数据,这样数据就会“浮”上来
//冒泡排序 for(int i=1;i<array.length;i++){ for(int j=i+1;j<array.length;j++){ int temp=0; //如果后面一个数小于前面的就交换 if(array[i]>array[j]){ temp=array[j]; array[j]=array[i]; array[i]=temp; } } }
这段代码相信大家都能看懂,个人觉得如果面试的时候有这样的冒泡排序但是答不上来的话,真的够丢脸的
2.效率稍高一些的排序【选择排序】
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。
简要的说就是先取出或假设一个最小或最大的数,之后在剩下的数里挑选一个最小或最大的,再和我们认为的最小或最大的数比较。满足条件就交换位置
int temp=0; //这里开始逐个假设作为最小的数(这里是从大到小排序) for(int i=0;i<array.length-1;i++){ //假设一个最小的数 int minVal=array[i]; //最小数的下标 int minIndex=i; //接下来和后面的数进行比较如果有更小的则前面的假设不成立 for(int j=minIndex+1;j<array.length;j++){ //假设不成立,则修改最小的数和下标 if(array[j]<minVal){ minVal=array[j]; minIndex=j; } } //把我们找到的最小的数和前面的交换 temp=array[i]; array[i]=array[minIndex]; array[minIndex]=temp; }
这个程序比起前面的冒泡排序效率稍微高了一些
3.三种排序效率最高的一种【插入排序】
插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。
下面是插入排序的代码片段
for(int i=0;i<array.length;i++){ int insertVal=array[i]; int insertIndex=i-1; //移动位置直到找到合适的位置 while(insertIndex>=0&&insertVal<array[insertIndex]){ array[insertIndex+1]=array[insertIndex]; insertIndex--; } if(i!=insertIndex+1){ array[insertIndex+1]=insertVal; } }
4 二分查找算法
要求:数字有序排列
下面是java中的递归实现
public static int search(int[] arr,int start,int end,int num){ //int position=-1; int middle=Math.round((start+end)/2); if(start>end){ //-1表示没有找到 return -1; } if(num==arr[middle]){ return middle; }else if(arr[middle]>num){ return search(arr,start,middle-1,num); }else if(arr[middle]<num){ return search(arr,middle+1,end,num); } return -1; }
以上就是我个人的小小总结,如果代码有问题希望大家指正