插入排序是排序算法的一种,它不改变原有的序列(数组),而是创建一个新的序列,在新序列上进行操作。

这里以从小到大排序为例进行讲解。


        插入排序的基本思想是,将元素逐个添加到已经排序好的数组中去,同时要求,插入的元素必须在正确的位置,这样原来排序好的数组是仍然有序的。
 
        在实际使用中,通常是排序整个无序数组,所以把这个无序数组分为两部分排序好的子数组和待插入的元素;
第一轮时,将第一个元素作为排序好的子数组,插入第二个元素;
第二轮,将前两个元素作为排序好的数组,插入第三个元素;
以此类推,第i轮排序时,在前i个元素的子数组中插入第i+1个元素。直到所有元素都加入排序好数组。

下面,以对 3  2  4  1 进行选择排序说明插入过程,使用j记录元素需要插入的位置。排序目标是使数组从小到大排列。

第1轮
[ 3 ]  [ 2  4  1 ]  (最初状态,将第1个元素分为排序好的子数组,其余为待插入元素)
[ 3 ]  [ 2  4  1 ]  (由于3>2,所以待插入位置j=1)
[ 2  3 ]  [ 4  1 ]  (将2插入到位置j)

第2轮
[ 2  3 ]  [ 4  1 ] (第1轮排序结果)
[ 2  3 ]  [ 4  1 ] (由于2<4,所以先假定j=2)
[ 2  3 ]  [ 4  1 ] (由于3<4,所以j=3)
[ 2  3  4 ]  [ 1 ] (由于4刚好在位置3,无需插入)

第3轮
[ 2  3  4 ]  [ 1 ] (第2轮排序结果)
[ 2  3  4 ]  [ 1 ] (由于1<2,所以j=1)
[1  2  3  4 ]    (将1插入位置j,待排序元素为空,排序结束)

算法总结及实现

选择排序对大小为N的无序数组R[N]进行排序,进行N-1轮选择过程。首先将第1个元素作为已经排序好的子数组,然后将剩余的N-1个元素,逐个插入到已经排序好子数组;。因此,在第 i轮排序时,前i个元素总是有序的,将第i+1个元素插入到正确的位置。

复制纯文本新窗口

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<iostream>
  4. using namespace std;
  5. void insert_sort(int a[],int &n);  //使用C++中引用操作;
  6. int main()
  7. {
  8. int num[] = {89, 38, 11, 78, 96, 44, 19, 25};
  9. //数据元素的个数:
  10. int N=sizeof(num)/sizeof(N[0]);
  11. insert_sort(num,N);
  12. for(int i=0; i<N; i++)
  13. cout<<num[i]<<endl;
  14. system("pause");
  15. return 0;
  16. }
  1. //插入排序实现,这里按从小到大排序
  2. void insert_sort(int a[],int &n) //n为数组a的元素个数,这里采用c++中的引用操作;
  3. {
  4. int t=0;
  5. for(int i=2-1; i<=n-1; i++)
  6. {
  7. if(a[i]<a[i-1])//首先找到元素a[i]需要插入的位置
  8. {
  9. t=a[i];
  10. for(int j=i-1;a[j]>t;j--)
  11. a[j+1]=a[j];
  12. //将元素插入到正确的位置
  13. a[j+1]=t;
  14. }
  15. }
  16. }

注意:插入排序是一种稳定的排序算法,不会改变原有序列中相同数字的顺序。

插入排序是在一个已经有序的小序列的基础上,一次插入一个元素。当然,刚开始这个有序的小序列只有1个元素,就是第一个元素。比较是从有序序列的末尾开始,也就是想要插入的元素和已经有序的最大者开始比起,如果比它大则直接插入在其后面,否则一直往前找直到找到它该插入的位置。如果碰见一个和插入元素相等的,那么插入元素把想插入的元素放在相等元素的后面。所以,相等元素的前后顺序没有改变,从原无序序列出去的顺序就是排好序后的顺序,所以插入排序是稳定的。

c语言--直接插入算法相关推荐

  1. R语言apriori算法进行关联规则挖掘(限制规则的左侧或者右侧的内容进行具体规则挖掘)、使用subset函数进一步筛选生成的规则去除左侧规则中的冗余信息、获取更独特的有新意的关联规则

    R语言apriori算法进行关联规则挖掘(限制规则的左侧或者右侧的内容进行具体规则挖掘).使用subset函数进一步筛选生成的规则去除左侧规则中的冗余信息.获取更独特的有新意的关联规则 目录

  2. R语言apriori算法进行关联规则挖掘(限制规则的左侧或者右侧的内容进行具体规则挖掘)、查看限制了规则的右侧之后挖掘到的规则(置信度排序,只查看左侧即可)

    R语言apriori算法进行关联规则挖掘(限制规则的左侧或者右侧的内容进行具体规则挖掘).查看限制了规则的右侧之后挖掘到的规则(置信度排序,只查看左侧即可) 目录

  3. R语言Apriori算法关联规则挖掘:使用interestMeasure函数评估挖掘到的规则(包括覆盖率(coverage)和FishersExactTest)、置信度最高的五条规则(top five

    R语言Apriori算法关联规则挖掘:使用interestMeasure函数评估挖掘到的规则(包括覆盖率(coverage)和FishersExactTest).置信度最高的五条规则(top five ...

  4. 【计算理论】计算复杂性 ( 阶段总结 | 计算理论内容概览 | 计算问题的有效性 | 语言与算法模型 | 可计算性与可判定性 | 可判定性与有效性 | 语言分类 ) ★

    文章目录 一.计算理论内容概览 二.计算问题的 有效性 三.语言 与 算法模型 四.可计算性 与 可判定性 五.可判定性 与 有效性 六.语言分类 一.计算理论内容概览 计算理论分为 形式语言与自动机 ...

  5. 【计算理论】可判定性 ( 通用图灵机和停机问题 | 可判定性 与 可计算性 | 语言 与 算法模型 )

    文章目录 一.通用图灵机和停机问题 二.可判定性 与 可计算性 三.语言 与 算法模型 一.通用图灵机和停机问题 利用 图灵 的结论 , 证明 有哪些 计算问题 是找不到 算法 进行判定的 ; 如 停 ...

  6. C语言经典算法 21-30

    目录 21 一个有序的数组插入一个数 22 将一个数组逆序输出 23 报号 求最后是谁 24 写一个统计字符串长度的函数 25 八进制转换为十进制 26 判断一个素数能被几个 9 整除 27 输入一组 ...

  7. C语言经典算法 11-20

    C语言经典算法 11-20 十一.求最大公约数和最小公倍数 十二.统计字符串数字,字母,符号的各个数量 十三.2+22+222+..... 十四.完数 十五.小球反弹问题 十六.猴子吃桃问题 十七.求 ...

  8. C语言经典算法 1-10

    目录 一.排列组合题 二.区间题 三.判断平方数相关 四.给你一个年月日判断是第几天 五.将3个数由小到大排序 六.九九乘法表 七.兔子繁殖数列 八.判断素数 九.水仙花数 十.因数分解 一.排列组合 ...

  9. 动图图解C语言插入排序算法,含代码分析

    C语言文章更新目录 C语言学习资源汇总,史上最全面总结,没有之一 C/C++学习资源(百度云盘链接) 计算机二级资料(过级专用) C语言学习路线(从入门到实战) 编写C语言程序的7个步骤和编程机制 C ...

  10. 最小生成树实验报告c语言,最小生成树(C语言, prim算法)

    图(来源:<>p250) #include #include #include /* * 邻接矩阵, prim普里姆算法(属贪婪算法),无向图,最小生成树 * 代码实现<>p2 ...

最新文章

  1. 深度丨2017年深度学习重大研究进展全解读
  2. 数据结构学习笔记(五):重识字符串(String)
  3. 两个月拿到N个offer,看看我是如何做到的
  4. python 重定向stdout_Python 犄角旮旯--重定向 stdout
  5. mongodb batchInsert
  6. Innodb中常见SQL语句设置的锁类型
  7. 开源 Android pdf 阅读器开发总结
  8. python程序员工资-Python工资高还是Java?
  9. 它!5 年代替狂卷的 CNN!
  10. libpng创建及编辑图片
  11. R语言---ggplot绘图
  12. [项目管理]项目管理常用的七大工具
  13. Data + AI Summit 2022 PPT 下载
  14. 阿阳网客:steam搬砖项目超完整版实操分享
  15. 2018年国考行测错题集(省级)
  16. 旭元数艺:只争朝夕 不负韶华
  17. 仿知乎日报图文小程序模板
  18. 全球与中国脉冲宽度调制(PWM)控制器市场深度研究分析报告
  19. 数学问题总结(题目合集)
  20. 网易云音乐mp3外链-真实地址下载方法

热门文章

  1. 新入职朋友说话时,一定不要用“你们”,用“咱们”
  2. ckc交易什么意思_期货交易中的标准仓单充抵保证金是什么意思?
  3. ajax里面可以alert吗,Javascript和AJAX,仅在使用alert()时有效
  4. mysql资源限制_超出了MariaDB / MySQL资源限制
  5. 查看环境列表_西门子COMOS软件开发定制学习8-查询列表间的数据交互
  6. activity 流程编辑器_最好用的流程编辑器bpmnjs系列之Viewer
  7. 人眼分辨 PPI_1080P=2K,分辨率≠清晰度?关于显示器大多数人都错了
  8. java数据结构编程问题_Java语言程序设计与数据结构第十一版(基础篇)第一章编程练习题答案...
  9. 代理(Proxy)和背靠背用户代理(B2BUA)
  10. 浅谈ajax同步、异步的问题