目录
一、前言
关于各种排序问题,是笔试面试中的经典问题,很多同学表示看的时候都懂了,用的时候全混了(没错就是我==)。所以为了方便复习(预习),下面整理了各种算法思想以及复杂度,当然还有代码实现。
二、七种经典排序
1.直接选择排序
简单来说,选择排序就是每次找未排序数组中的最小(或者最大)的记录并固定其位置
* 思想: ①对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换;
②接着对不包括第一个记录之外的其他记录进行第二轮比较,得到最小的记录并与第二个记录进行位置交换;
③重复该过程 直到全部排序
*时间复杂度:最好 最坏 平均时间均为O(n^2)
*辅助空间:O(1)
*稳定性:不稳定
Java代码实现直接选择排序:
public class SelectSort {
public static void selectSort(int[] a) {
int temp = 0; //用来放每趟中的最小值
int index = 0; //用来放上面最小值temp对应的数组下标
int len = a.length; //数组长度
for(int i=0;i<len;i++) {//某一趟
temp = a[i];
index = i;
for(int j=i+1;j<len;j++) { //在该趟找出未排序部分的最小值放temp中,从前往后依次比较
if(a[j] < temp) {
temp = a[j];
index = j;
}
}
if(index != i) { //找到最小值位置且不是a[i],就进行交换
a[index] = a[i];
a[i] = temp; //交换第i个位置数据
}
}
}
public static void main(String[] args) {
int[] array = {5,4,3,7,6,8,10,1};
System.out.print("原数组:");
for(int ai : array) {
System.out.print(ai+" ");
}
System.out.println();
selectSort(array);
System.out.print("选择排序后:");
for(int ai : array) {
System.out.print(ai+" ");
}
}
}
2.直接插入排序
* 算法思想: 初始时假设第一个记录自成一个有序序列,其余记录均为无序序列。
* 接着从第二个记录开始,按照记录的大小依次将当前处理的记录插入到其之前的有序序列中,
* 直到最后一个记录插入到有序序列中为止
* 时间复杂度:最好时间:O(n);最坏 平均:O(n^2)
* 辅助空间:O(1)
* 稳定性:稳定的!!!
Java代码实现插入排序:
public class InsertSort {
public static void insertSort(int[] a) {
int len = a.length; //数组的长度
if(a != null) {
for