2019独角兽企业重金招聘Python工程师标准>>>

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

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

基本思想及举例说明

插入排序的基本思想是,将元素逐个添加到已经排序好的数组中去,同时要求,插入的元素必须在正确的位置,这样原来排序好的数组是仍然有序的。

在实际使用中,通常是排序整个无序数组,所以把这个无序数组分为两部分排序好的子数组和待插入的元素。第一轮时,将第一个元素作为排序好的子数组,插入第二个元素;第二轮,将前两个元素作为排序好的数组,插入第三个元素。以此类推,第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. #define N 8
  4. void insert_sort(int a[],int n);
  5. //插入排序实现,这里按从小到大排序
  6. void insert_sort(int a[],int n)//n为数组a的元素个数
  7. {
  8. //进行N-1轮插入过程
  9. for(int i=1; i<n; i++)
  10. {
  11. //首先找到元素a[i]需要插入的位置
  12. int j=0;
  13. while( (a[j]<a[i]) && (j<i))
  14. {
  15. j++;
  16. }
  17. //将元素插入到正确的位置
  18. if(i != j) //如果i==j,说明a[i]刚好在正确的位置
  19. {
  20. int temp = a[i];
  21. for(int k = i; k > j; k--)
  22. {
  23. a[k] = a[k-1];
  24. }
  25. a[j] = temp;
  26. }
  27. }
  28. }
  29. int main()
  30. {
  31. int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};
  32. insert_sort(num, N);
  33. for(int i=0; i<N; i++)
  34. printf("%d ", num[i]);
  35. printf("\n");
  36. system("pause");
  37. return 0;
  38. }

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

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

转载于:https://my.oschina.net/HeroOneHY/blog/919889

C语言插入排序算法及代码相关推荐

  1. c语言插入排序算法_插入排序算法,流程图和C,C ++代码

    c语言插入排序算法 In the last article, we discussed about the bubble sort with algorithm, flowchart and code ...

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

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

  3. c语言插入排序_还有这种操作?C语言插入排序算法,一点就透

    插入排序算法是所有排序方法中最简单的一种算法,其主要的实现思想是将数据按照一定的顺序一个一个的插入到有序的表中,最终得到的序列就是已经排序好的数据. 更多C/C++资料群文件:569268376 直接 ...

  4. c语言插入排序算法伪代码,排序算法——插入排序(C语言实现)

    原理 默认数组的第一个数据是有个有序数组,由于只有一个数据,肯定是有序队列.从乱序数组的第二个位置开始,与之前的有序数组中的数据依次作比较,找到合适的位置将该数据插入有序数组,直到将最后一个数据插入有 ...

  5. 插入排序算法C++代码实现

    插入排序过程如图所示 代码: #include<iostream> #include<vector> using namespace std; void selectsort( ...

  6. c语言dfs算法全排列代码,c语言dfs解决全排列问题

    如1,2,3三个元素的全排列为: 1,2,3 1,3,2 2,1,3 2,3,1 3,1,2 3,2,1 共3*2*1=6种 代码简单实现n个元素的全排列 #include #define N 5 i ...

  7. c语言快速排序算法代码,c语言快速排序算法示例代码分享

    #include #include #include #define RANDOM(i) (rand()%i) #define N 9    //设置数组长度 //分区操作 int Partition ...

  8. 插入排序算法(基于Java实现)

    title: 插入排序算法(基于Java实现) tags: 插入算法 插入排序算法原理及代码实现: 一.插入排序算法的原理 首先,我们将数组中的数据分为两个区间,已排序区间和未排序区间.初始已排序区间 ...

  9. 数据结构之插入排序:折半插入排序算法

    排序算法:折半插入排序算法 思维导图: 折半插入排序算法的定义: 折半插入排序算法的原理: 折半插入排序算法的代码实现: 折半插入排序算法的性能: 思维导图: 折半插入排序算法的定义: 插入排序时查找 ...

最新文章

  1. BZOJ4292 : [PA2015]Równanie
  2. 大佬教你Android如何实现时间线效果
  3. Django之MVC框架与MTV框架详解
  4. 贪吃蛇游戏(c/c++)
  5. 最好的oracle笔记,Oracle学习笔记(一)
  6. HTML 文档的字符编码未声明。如果该文件包含 US-ASCII 范围之外的字符,该文件将在某些浏览浏览器配置中呈现为乱码。页面的字符编码必须在文档或传输协议层声明。
  7. matlab V7.0 R14 安装教程
  8. POJ 3280 Cheapest Palindrome(DP)
  9. 证券交易1-交易系统简介
  10. 最全,176个HFSS仿真实例模型文件分享
  11. IC卡参数公钥之 AID和RID
  12. 永琳的竹林迷径(path)
  13. 如何用化学软件画立体图?
  14. 基于爱奇艺HCDN视频分发网络的开放缓存
  15. android 10.0 在系统源码下生成jks系统签名文件
  16. 2023首届大学生算法大赛 - 村庄
  17. RemoteView流程
  18. mybatis-plus 自动生成代码
  19. 张凯复旦大学计算机学院,徐丰 - 师资队伍 - 复旦大学信息科学与工程学院
  20. 用史上最牛学习法自学编程,不香吗?

热门文章

  1. LockSupport的源码实现原理以及应用
  2. MongoDB学习路线
  3. java中的动态代理----自己手动实现
  4. [LeetCode] Palindrome Linked List
  5. 文档中根元素后面的标记格式必须正确。
  6. 一步一步SharePoint 2007之五:向网站中添加一个子网站
  7. 利用XML实现通用WEB报表打印 卢彦
  8. Linux网络编程——黑马程序员笔记
  9. 安卓APP_ Fragment(3)—— Fragment的生命周期
  10. python堆排序算法_python 排序 堆排序