插入排序也是最简单的一类排序方法,我今天介绍的也是插入排序里最直观且浅显易懂的直接插入排序。对这个很简单的排序,记得当时也是花了近两个晚上才搞懂它的原理的,接下来就来介绍一下我的思路:
我曾经也在网上搜索了很多别人写的博客也百度看了别人的想法,但怎么说呢,大概是一百个人就会有一百种想法,也可能是我没有看到正中我心意的那一篇博客,导致看了很多别人写的代码以及图片示例都没有解决我心里的疑问和不解。现在我就来写一下我对这个排序的理解,希望曾经跟我一样有这样疑问的朋友,能在我的博客里找到答案。
直接上例子,通过例子来讲解我的思路:
首先来定义一个整型一维数组a[6] = {2, 6, 5, 3, 4, 1},
我们令数组下标 i 从0开始,假定第一个数即a[0] = 2 是有序的,然后从第二个数i = 1 时从后往前开始枚举, 枚举的过程就是找一个合适的位置把当前枚举的数存放进去即插进去。这时候要定义另一个整型变量 j 来辅助判断, 每一次循环 j = i。
用整型变量 temp 来临时存放每一次需要排序的元素, 每一次判断的条件就是在一定条件下temp 是否小于前一个元素(默认从小到大排序),易知这一次排序6 > 2, 所以不需要进行交换,接着我们来进行下一趟排序;
易发现此时当前项即temp = 5 比 a[j - 1] 项小, 所以此时令 a[j] = a[j - 1], 即让原来的 j - 1项往后移一位,然后 j-- 让 j 继续枚举前面的数,原来的 i= 2 的原始值已经存放在了temp 里, 即
J 继续向前枚举的时候,我们发现,此时的temp 并不满足小于a[j-1] ,所以将 temp 插入存放在 a[j]里, 这一次的排序已经排完,即
此时temp 存放的 数值 3 小于 a[j-1] , 所以将a[j-1]赋值给a[j] ,然后 j 继续向前枚举。
此时 temp 存放的数值3 仍旧小于a[j-1]项, 所以继续将a[j-1] 赋值给a[j], 即将a[j-1]向后移一项,然后j 继续向前枚举:
此时temp 存放的数值3 比a[j-1]大, 所以此时就将temp 赋值给a[j]来完成该次排序,即:
此时当前项 temp 存放的 数值4 比前一项a[j-1]小,所以令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
此时 temp 存放的数值4 仍旧比a[j-1] 要小,继续令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
到此,temp 存放的数值 4 比a[j-1] 大,不再需要继续向前枚举,直接令a[j] = temp 来完成当前项的排序,即
此时 temp 存放的数值1 小于a[j-1]项,所以令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
此时 temp 存放的数值1 依然小于a[j-1]项,所以令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
此时 temp 存放的数值1 依然小于a[j-1]项,所以令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
此时 temp 存放的数值1 依然小于a[j-1]项,所以令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
此时 temp 存放的数值1 依然小于a[j-1]项,所以令a[j-1]的值赋值给a[j] 来使a[j-1] 的值后移一位,令j 继续向前枚举,即
至此,j 已经到达了数组最前,且temp 已经无法满足小于 a[j-1]了,所以此时跳出while循环,顺势将temp 的数值赋值给a[j],至此,所有的数都已经完成排列,最后i <= 5有序, 即
最后,上代码:
#include<iostream>
using namespace std;
int main() {
int a[6] = { 2, 6, 5, 3, 4, 1};
int temp, i, j;
int n = 6;
for (i = 1; i < 6; i++) { // 数组的下标是从0开始的
// 这里从第二个数开始枚举 即假定第一个数是有序的
temp = a[i]; j = i; // 这里temp 临时储存每一次需要排序的数
while (j >= 1 && temp < a[j - 1]) {
a[j] = a[j - 1];
j--;
}
a[j] = temp;
}
for (i = 0; i < 6; i++) {
cout << a[i] << " ";
}
cout << endl;
return 0;
}
如有不对之处,欢迎批评指正!
文章浏览阅读451次。dev/mem: 物理内存的全镜像。可以用来访问物理内存。/dev/kmem: kernel看到的虚拟内存的全镜像。可以用来访问kernel的内容。调试嵌入式Linux内核时,可能需要查看某个内核变量的值。/dev/kmem正好提供了访问内核虚拟内存的途径。现在的内核大都默认禁用了/dev/kmem,打开的方法是在 make menuconfig中选中 device drivers --> ..._dev/mem 源码实现
文章浏览阅读7.1k次,点赞2次,收藏19次。vxe-table,一个小众但功能齐全并支持excel操作的vue表格组件_vxe-table
文章浏览阅读62次。参考:http://www.ruanyifeng.com/blog/2016/01/babel.htmlBabelBabel是一个广泛使用的转码器,可以将ES6代码转为ES5代码,从而在现有环境执行// 转码前input.map(item => item + 1);// 转码后input.map(function (item) { return item..._让开发环境支持bable
文章浏览阅读2.8k次,点赞6次,收藏29次。摘要:FPGA视频处理FIFO的典型应用,视频输入FIFO的作用,视频输出FIFO的作用,视频数据跨时钟域FIFO,视频缩放FIFO的作用_fpga 频分复用 视频
文章浏览阅读575次。【代码】R语言:设置工作路径为当前文件存储路径。_r语言设置工作目录到目标文件夹
文章浏览阅读452次。格式:background: linear-gradient(direction, color-stop1, color-stop2, ...);<linear-gradient> = linear-gradient([ [ <angle> | to <side-or-corner>] ,]? &l..._background线性渐变
文章浏览阅读1k次,点赞26次,收藏8次。第十三届蓝桥杯青少年组python编程省赛真题一、题目要求(注:input()输入函数的括号中不允许添加任何信息)1、编程实现给定一个正整数N,输出正整数N中各数位最大的那个数字。例如:N=132,则输出3。2、输入输出输入描述:只有一行,输入一个正整数N输出描述:只有一行,输出正整数N中各数位最大的那个数字输入样例:
文章浏览阅读2.2k次。一个网络协议主要由以下三个要素组成:1.语法数据与控制信息的结构或格式,包括数据的组织方式、编码方式、信号电平的表示方式等。2.语义即需要发出何种控制信息,完成何种动作,以及做出何种应答,以实现数据交换的协调和差错处理。3.时序即事件实现顺序的详细说明,以实现速率匹配和排序。不完整理解:语法表示长什么样,语义表示能干什么,时序表示排序。转载于:https://blog.51cto.com/98..._网络协议三要素csdn
文章浏览阅读153次。主要的思想,将所有的系统都可以看作两部分,真正的数据log系统和各种各样的query engine所有的一致性由log系统来保证,其他各种query engine不需要考虑一致性,安全性,只需要不停的从log系统来同步数据,如果数据丢失或crash可以从log系统replay来恢复可以看出kafka系统在linkedin中的重要地位,不光是d..._the log: what every software engineer should know about real-time data's uni
文章浏览阅读746次。伟大是熬出来的 目录 前言 引言 时间熬成伟大:领导者要像狼一样坚忍 第一章 内圣外王——领导者的心态修炼 1. 天纵英才的自信心 2. 上天揽月的企图心 3. 誓不回头的决心 4. 宠辱不惊的平常心 5. 换位思考的同理心 6. 激情四射的热心 第二章 日清日高——领导者的高效能修炼 7. 积极主动,想到做到 8. 合理掌控自己的时间和生命 9. 制定目标,马..._当狼拖着受伤的右腿逃生时,右腿会成为前进的阻碍,它会毫不犹豫撕咬断自己的腿, 以
文章浏览阅读285次。在当今的大数据时代,人们对高速度和高带宽的需求越来越大,迫切希望有一种新型产品来作为高性能计算和数据中心的主要传输媒质,所以有源光缆(AOC)在这种环境下诞生了。有源光缆究竟是什么呢?应用在哪些领域,有什么优势呢?易天将为您解答!有源光缆(Active Optical Cables,简称AOC)是两端装有光收发器件的光纤线缆,主要构成部件分为光路和电路两部分。作为一种高性能计..._aoc 光缆
文章浏览阅读2.2k次。在“桌面”上按快捷键“Ctrl+R”,调出“运行”窗口。接着,在“打开”后的输入框中输入“Gpedit.msc”。并按“确定”按钮。如下图 找到“用户配置”下的“Windows设置”下的“Internet Explorer 维护”的“连接”,双击选择“自动浏览器配置”。如下图 选择“自动启动配置”,并在下面的“自动代理URL”中填写相应的PAC文件地址。如下..._設置proxy腳本