前言
插入排序:
- 每次插入排序之后(0至i)的元素是有序的。
- 每次进行插入排序都是选取(i+1)的值为tmp和i之前的值依次比较,如果tmp小于比较值,则比较值后移一位,继续比较。否则退出比较。
数组下标为:0~n
插入排序从数组下标第i个元素tmp,依次和数组下标小于i的元素值比较,数组下标即为j。
- 如果tmp < a[j],则j下标元素移动到j+1的位置。j–再次循环,且j>0。
- 如果tmp>=a[j], 退出循环。
- 最好将arr[j] = tmp;
一 Java实现插入排序
代码实现
/**
* 插入排序
*/
public class InsertSort {
public static void main(String[] args){
run(100000);
}
/**
* 测试示例
*/
public static void run(int num){
int[] arr = new int[num];
for(int i = 0; i < arr.length; i++){
arr[i] = (int) (Math.random() * num);
}
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println("开始时间:"+sdf.format(new Date()));
sort(arr);
//数据小的时候,可以采用下列方法打印数据
// System.out.println(Arrays.toString(arr));
System.out.println("结束时间:"+sdf.format(new Date()));
}
/**
* 排序
*/
public static void sort(int[] arr){
for(int i = 1; i < arr.length; i++){
int j = i;
int tmp = arr[i];
//进行排序之后i索引之前的数据都是有序的
while(j > 0 && arr[j -1] > tmp){
arr[j] = arr[j - 1];
j--;
}
arr[j] = tmp;
}
}
}
二 插入排序动画代码
排序动画代码地址
https://gitcode.com/swg321321/algorithm
该博客详细介绍了插入排序的原理,通过Java代码展示了插入排序的实现过程,并提供了排序动画代码的链接,帮助读者深入理解插入排序的动态效果。

560

被折叠的 条评论
为什么被折叠?



