经典算法之插入排序
发布日期: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&&tmp
3,3,2 j--; } //存在比其小的数,把记录的tmp赋值给刚才的空位.3,3,2--->1,3,2 if (j!=i){
arr[j]=tmp; } } return arr; }
上一篇:将本地已有的maven工程导入工作空间
下一篇:冒泡排序和二分查找

发表评论

最新留言

感谢大佬
[***.8.128.20]2025年03月27日 01时59分50秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

RDD行动操作算子 --- fold(初始值)、reduce 2019-03-04
【Python数据分析与处理 实训02】 ---2012欧洲杯信息分析(数据过滤与排序) 2019-03-04
【Python数据分析与处理 实训04】--- 探索1960 - 2014美国犯罪数据(时间序列处理应用) 2019-03-04
KeyError: “[‘xxxx‘] not found in axis“ 2019-03-04
【Python数据分析与处理 实训05】--- 探索虚拟姓名数据(数据合并) 2019-03-04
java编程常见类型题 --- 面向对象编程、程序逻辑(金字塔)、多线程同步 2019-03-04
java编程常见类型题 --- 程序逻辑(最小台阶)、多线程(计算读取)、Swing布局(国际棋盘) 2019-03-04
【MapReduce】基础案例 ---- 自定义OutputFormat <根据内容输出到指定文件目录中> 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
javascript(7)——定义函数的两种方式以及使用的时候传入多个参数的情况,arguments和...rest 2019-03-04