一种简单的直接插入排序精解

直接插入排序,就像是桌子上一叠正面向下的扑克从小到大地依次拿到自己的手上。

1,显然拿到的第一张扑克(假如是3)是不用比较的,而且可以认为,它是有序的。

2,拿到第二张牌(假如是2)的时候,我们只要和第一张比较,放到合适的位置(现在是2,3),保持有序。

3,接着拿到第三张牌,我们只要和原来有序的序列(2,3)比较组成一个元素加一个的新有序序列即可。

(我们只要从右到左用在原序列一个个比较即可,如是5,只比较一次就可以决定放在3前,如果是1,那就比较两次)

详解如下图:

要点:

1,大循环从第二个元素开始,倒着比较

2,小循环的条件有两种情况

3,i在一趟比较的最后要加1,向后一格置入新元素

特征:

1,插入排序是原址排序,最多用了一个辅助空间来放临时元素

2,新元素之前的部分是本问题的子问题的求解结果

3,完全逆序的比较性能最差(内层循环的次数最多)

for(j=1
;  j< arr.length ; j++)

{

key = arr[ j] ;//取出当前要插入比较的新元素

i = j-1;//小循环指示器

while( i> -1 &&
arr[i]>key) {//小循环负责在已经有序的部分中找个合适的位置

arr[i+1] = arr [i] ;//有序部分比新来元素较大者后移

--i;//继续向前寻找位置

}

i=i+1;

arr[i] =  key;//无论是否进入了小循环,把key放在i+1的位置总是对的

//没有进入小循环的i和j是同一个位置

}

本文已完结;

by [email protected]

时间: 2024-08-18 06:44:14

一种简单的直接插入排序精解的相关文章

《Cocos2d-x游戏开发实战精解》学习笔记3--在Cocos2d-x中播放声音

<Cocos2d-x游戏开发实战精解>学习笔记1--在Cocos2d中显示图像 <Cocos2d-x游戏开发实战精解>学习笔记2--在Cocos2d-x中显示一行文字 之前的内容主要都是介绍如何在屏幕上显示图像,事实上除了图像之外,音乐的播放也可以被理解为一种显示的方式,本节将学习在Cocos2d-x中播放声音的方法. (1)在HelloWorld.h中对HelloWorld类进行如下定义: class HelloWorld : public Cocos2d::Layer { pu

《Cocos2d-x游戏开发实战精解》学习笔记1--在Cocos2d中显示图像

Cocos2d-x中的图像是通过精灵类来显示的.在Cocos2d-x中游戏中的每一个角色.怪物.道具都可以理解成是一个精灵,游戏背景作为一种特殊的单位将其理解成是一个精灵也没有什么不妥.在源文件本章目录下的项目ChapterThree03就展示了使用Cocos2d-x实现简单游戏开始界面的方法,主要就是通过精灵类来显示图像,其关键代码如范例3-5所示. [范例3-5 在Cocos2d-x中显示图像] Size size = Director::getInstance()->getVisibleS

Android更新Ui进阶精解(二)

<代码里的世界> 用文字札记描绘自己 android学习之路 转载请保留出处 by Qiao http://blog.csdn.net/qiaoidea/article/details/45115047 Android更新Ui进阶精解(一) android ui线程检查机制 Android更新Ui进阶精解(二) android 线程更新UI机制 1.回顾 第一篇讲了对Ui线程更新的方法和见解,然后接着讲了线程检查机制,这里来详细分析下更新Ui的核心--Android中消息系统模型.当然,这里要

iOS设计模式 - (2)UML类间关系精解

在正式讲设计模式之前, 介绍一下UML类图之间的关系还是非常有必要的, 由于一些教程, 书籍, 包含我之后的文章, 都会大量使用类图, 去描写叙述各个类之间的关系.这是一种非常直观, 简约的方式. 当然, 能力, 精力有限, 这里的UML的介绍也仅仅局限与几种常见的类间关系. 包含: 继承.实现.依赖.关联.聚合.组合 在次之前, 假设看不懂类图, 能够先看一下我之前写的一篇文章 : 具体解释八大UML类图符号的表示法 iOS - UML类间关系精解           by Colin丶 转载

腾讯云无服务器云函数架构精解

欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 分享人:陈杰,腾讯云架构平台部技术专家,10年云计算经验,现供职于腾讯架构平台部,负责弹性计算及云函数技术研发,致力于提供领先的基础设施平台以提升资源利用率及优化提升程序员开发运维效率. 继虚拟机,容器技术,无服务器化成为新的行业热点,无服务器云函数可以让用户无需关心服务器的部署运营,只需开发最核心的业务逻辑,即可实现上线运营,具备分布容灾能力,可依据负载自动扩缩容,按照实际调用次数与时长计费.本次主要分享腾讯云无服务器云函数在技术实

sed实例精解--例说sed完整版

原文地址:sed实例精解--例说sed完整版 作者:xiaozhenggang 最近在学习shell,怕学了后面忘了前面的就把学习和实验的过程记录下来了.这里是关于sed的,前面有三四篇分开的,现在都把它们弄到了一起,并做了一些调整,二十多页,有点长啦.不过大部分都是例子来着,呵呵. 在电脑前坐太久了还真是不行,脖子都歪啦!强烈建议各位找点时间多动动,多动动!还是身体重要嘛!!! 我的实验环境是: fedora 14 ,bash. 在实验中遇到了一些问题,都在后面的例子中提到啦.有些问题纠结了好

危机的元凶——“大乘佛法三藏”现代文精解

特别声明: 本文是在响应中央改革的号召,也是一个普通公民学习"邓小平理论","摸着石头过河"的一次小结. 本人是辨证唯物主义者,不是形而上学的唯物主义者,更加不是唯心主义者.本文紧扣事实,观点明确,逻辑完整,请勿断章取义.若不能完全理解,请勿效仿. 摘要: 本文试论述经济危机产生的根源,并从根源的角度提出根治经济危机的解决办法. 正文一.<狮子吼>现代文版:依据事实,简要论述经济危机发生发展的过程. 正文二.<六道轮回心经>.<法华经&

iOS设计模式 - UML类间关系精解

在正式讲设计模式之前, 介绍一下UML类图之间的关系还是很有必要的, 因为一些教程, 书籍, 包括我之后的文章, 都会大量使用类图, 去描述各个类之间的关系.这是一种非常直观, 简约的方式. 当然, 能力, 精力有限, 这里的UML的介绍也仅仅局限与几种常见的类间关系. 包括: 继承.实现.依赖.关联.聚合.组合 在次之前, 如果看不懂类图, 可以先看一下我之前写的一篇文章 : 详解八大UML类图符号的表示法 iOS - UML类间关系精解           by Colin丶 转载请注明出处

【刘文彬】【精解】EOS智能合约演练

原文链接:醒者呆的博客园,https://www.cnblogs.com/Evsward/p/eos-contract.html EOS,智能合约,abi,wasm,cleos,eosiocpp,开发调试,钱包,账户,签名权限 热身 本文旨在针对EOS智能合约进行一个完整的实操演练,过程中深入熟悉掌握整个EOS智能合约的流程,过程中出现的问题也会及时研究并入我们自己的知识体系.本文会主要跟随EOS官方Wiki的智能合约部分进行研究学习,主要分为 开启一个私有链 创建钱包 载入基础IO的智能合约支