插入排序推导过程:
public static void insertSort(int[] arr) {
//使用逐步推导的方式来
//第一轮{101,34,119,1}=》{34,101,119,1}
//定义待插入的数
int insertVal = arr[1];
int insertIndex = 1 - 1;//即arr[1]的前面这个数的下标
//给insertVal 找到插入的位置
//说明
//1、insertIndex >=0保证在给insertVal 找到插入位置 不越界
//2、insertVal < arr[insertIndex] 待插入的数,还没有找到插入的位置
//3、就需要将 arr[insertIndex] 后移
while (insertIndex >= 0 && insertVal < arr[insertIndex]) {
arr[insertIndex + 1] = arr[insertIndex];//arr[insertIndex]
insertIndex--;
}
//当退出while循环时,说明插入的位置找到,insertIndex +1
//举例:理解不了,会debug
arr[insertIndex + 1] = insertVal;
System.out.println("第一轮插入");
System.out.println(Arrays.toString(arr));
}
插入排序封装方法:
public static void insertSort(int[] arr) {
int insertVal =0;
int insertIndex =0;
for (int i = 1; i < arr.length; i++) {
//定义待插入的数
insertVal = arr[i];
insertIndex = i - 1;//即arr[1]的前面这个数的下标
//给insertVal 找到插入的位置
//说明
//1、insertIndex >=0保证在给insertVal 找到插入位置 不越界
//2、insertVal < arr[insertIndex] 待插入的数,还没有找到插入的位置
//3、就需要将 arr[insertIndex] 后移 如果是从大到小insertVal > arr[insertIndex]
while (insertIndex >= 0 && insertVal < arr[insertIndex]) {
arr[insertIndex + 1] = arr[insertIndex];//arr[insertIndex]
insertIndex--;
}
//当退出while循环时,说明插入的位置找到,insertIndex +1
//举例:理解不了,会debug
//这里我们判断是否需要赋值
if (insertIndex+1 != i){
arr[insertIndex + 1] = insertVal;
}
System.out.println("第" + (i) + "轮插入");
System.out.println(Arrays.toString(arr));
}
}
main方法及8w随机数运行时间测试:
public static void main(String[] args) {
//int[] arr = {101, 34, 119, 1};
int[] arr = new int[80000];
for (int i = 0; i < 80000; i++) {
arr[i] = (int) (Math.random() * 80000);//生成一个[0,80000) 随机数
}
Date date = new Date();
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String dateStr = simpleDateFormat.format(date);
System.out.println("排序前的时间是=" + dateStr);
insertSort(arr);
Date date1 = new Date();
String dateStr1 = simpleDateFormat.format(date1);
System.out.println("排序后的时间是=" + dateStr1);
}