二:排序基础:2:插入排序;

本文详细介绍了插入排序的基本思想、循环不变量、基本实现、代码改写和优化,特别是优化后仅需4次赋值操作。此外,还讨论了插入排序在近乎有序数据中的优秀表现,对比了它与选择排序的差异。文章附带了从后向前排的插入排序实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

说明:

(1)本篇博客介绍插入排序;包括:插入排序基本思想,代码实现,算法优化,和选择排序相比插入排序的优点,从后向前排的方式实现插入排序;

(2)声明:如果是百万级的数据,插入排序可能需要十几分钟,还是比较慢的;所以后面会介绍其他更加有效的排序算法;

目录

一:插入排序,简介;

1.插入排序,基本思想; 

2.插入排序,循环不变量;

二:插入排序,基本实现;

1.插入排序代码:InsertionSort类;(重点!)

2.工具类,生成指定长度的随机数组:ArrayCenerator类;

3.一个整合的工具类,调用具体的排序算法,并检测排序结果是否OK:SortingHelper类;

4.Main方法所在的类,调用:TestMain类;

5.运行结果;

三:插入排序,改写;(这儿仅仅是写法上的改变;比如,我就不喜欢这种改写的写法;) 

四:插入排序,引入临时变量来优化;(在实际中,尽量采用这种优化的做法)

1.优化说明;

2.优化实现;

3.测试;

五:插入排序的一个特性:对于近乎有序的数据,其实际效果很好;

1.时间复杂度;

2.插入排序,特性;(和选择排序的比较!)

六:附加:从后向前排的方式,实现插入排序;


一:插入排序,简介;

1.插入排序,基本思想; 

比如,我们在玩扑克牌的时候,抓了一手牌之后,我们要把这些牌排序时候,在实际中,我们一般采用的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值