
经典算法之插入排序
发布日期:2021-05-06 23:31:23
浏览次数:36
分类:技术文章
本文共 740 字,大约阅读时间需要 2 分钟。
插入排序
将一个序列的第一个元素固定作为有序序列,扫描剩余元素并插入到有序数列的合适位置;时间复杂度O(n)~O(n²),比较稳定的!
算法步骤
1.待排序序列中挑出第一个元素作为有序序列固定,剩余未无序序列
2.从头到尾扫描未排序无序序列,将扫描到的每个元素都插入到有序序列的合适位置直接上代码
/** * 插入排序,固定住第一个,遍历剩下的并插入到合适位置。 * */ public int[] insertSort(int[] sourceArray){ int [] arr=Arrays.copyOf(sourceArray,sourceArray.length); //27, 15, 36, 22, 89, 33, 76, 1, 0, 100 for (int i = 1; i < arr.length; i++) { //记录要插入的数据 int tmp=arr[i]; int j=i; //这个循环是为了比较j之前的最小值,并插入到合适位置 while (j>0&&tmp3,3,2 j--; } //存在比其小的数,把记录的tmp赋值给刚才的空位.3,3,2--->1,3,2 if (j!=i){ arr[j]=tmp; } } return arr; }
发表评论
最新留言
感谢大佬
[***.8.128.20]2025年03月27日 01时59分50秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
RDD行动操作算子 --- fold(初始值)、reduce
2019-03-04
【Python数据分析与处理 实训02】 ---2012欧洲杯信息分析(数据过滤与排序)
2019-03-04
KeyError: “[‘xxxx‘] not found in axis“
2019-03-04
【Python数据分析与处理 实训05】--- 探索虚拟姓名数据(数据合并)
2019-03-04
java编程常见类型题 --- 面向对象编程、程序逻辑(金字塔)、多线程同步
2019-03-04
【Android】 模拟器上运行程序报错
2019-03-04
【sklearn练习】KMeans ---- iris(鸢尾花)数据集聚类评估
2019-03-04
【HTML5 CSS】display和visibility的区别
2019-03-04
java线程(4)——使用多个线程操作同一个对象(买票的例子)
2019-03-04
前端HTML中表单action属性的作用
2019-03-04
java线程(17)——Lock锁,三个线程抢票加上lock锁后变成三个线程排队买票
2019-03-04
java线程(19)——信号灯法,电视播放,生产者与消费者的案例
2019-03-04
java线程(20)——Runnable线程池
2019-03-04
计算机网络ip知识点
2019-03-04
react(3)——导入了正确的包,但是运行不出来,原因是因为导入包的顺序有问题
2019-03-04
react(10)——三大属性state,props,refs,总结其特点
2019-03-04