插入排序是稳定排序,时间复杂度最低为O(n),最高为O(n^2),平均为O(n^2)。

插入排序是将数组分为两部分,一部分已经排好序,另一部分未排好序,每次从未排好序的部分取第一个元素插入到已经排好序的部分正确的位置,如此循环n-1次。

就好像你手里有十张牌,左手有一张,右手有九张。每次从右手的牌中取最左边的一张插入到左手的牌里,右手的牌插完了,排序也完成了。

编写代码要点:

  1. 时间复杂度是O(n^2),意味着有双重循环。外面大循环代表插入的轮次,因为一开始左手有一张牌,所以只需要插入n-1次即可,也就是每次插入都从左手牌末尾元素的下标+1开始。
  2. 内层循环是从后方前反向遍历,因为要插入到正确的位置,需要给这个待插入的元素挪一个位置,所以在待插入的位置后面的所有元素都要整体后移一个位置,覆盖掉待插入元素初始的位置,然后把待插入的元素放置在空出来的位置即可。因为在元素整体后移给待插入元素挪位置的时候会覆盖掉待插入元素原本的位置,所以需要用一个元素来保存待插入的元素。

插入排序代码如下:

#include <stdio.h>

void insertSort(int arr[], int n) {
int i, j;
int currentElement;
// 前i个元素有序,初始情况只有一个有序组,也就是数组的第一个元素,故i=1
for (i = ; i < n; ++i) {
currentElement = arr[i]; // 保存当前要插入的元素,因为之后移动数组元素的时候会覆盖掉当前的元素
// 从后向前遍历,找到插入位置,也就是最后一个比待插入的元素小的元素
// 从待插入的前一个元素开始遍历,所以j=i-1,遍历到末尾,也就是数组开头,i=0
for (j = i - ; j >= ; --j) {
if (arr[j] > currentElement) {
arr[j + ] = arr[j];
} else {
break; // 找到了插入元素的位置,结束循环
}
}
// 此时arr[j]是<currentElement的,它并没有被移动,也没有留出空缺,空缺在它身后
// 故把currentElement赋值给arr[j]身后的空缺,也就是arr[j+1]
arr[j + ] = currentElement;
}
} int main() {
int i = ;
int arr[] = {, , , , , , , , , };
insertSort(arr, );
for (i = ; i < ; ++i) {
printf("%d ", arr[i]);
}
return ;
}

插入排序,C语言实现的更多相关文章

  1. 插入排序_C语言_数组

    插入排序_C语言_数组 #include <stdio.h> void insertSort(int *); int main(int argc, const char * argv[]) ...

  2. 插入排序——C语言

    插入排序 插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法.它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入.  (每步将一个待 ...

  3. 插入排序C语言版本

    算法思路:        每趟将一个待排序的元素作为关键字,按照其关键字值的大小插入到已经排好的部分的适当位置上,直到插入完成.        数组中待排序的关键字前面的数据为已经排序的数据,关键字插 ...

  4. 希尔排序——C语言

    希尔排序 希尔排序是插入排序的一种,又称“缩小增量排序”,希尔排序是直接插入排序算法的一种更高效的改进版本,关于插入排序可以看下这篇随笔:插入排序——C语言 (图片来源:https://www.cnb ...

  5. 2-路插入排序(2-way Insertion Sort)的C语言实现

    原创文章,转载请注明来自钢铁侠Mac博客http://www.cnblogs.com/gangtiexia   2-路插入排序(2-way Insertion Sort)的基本思想:     比fis ...

  6. 折半插入排序(Binary Insertion Sort)的C语言实现

    原创文章,转载请注明来自钢铁侠Mac博客http://www.cnblogs.com/gangtiexia   折半插入排序(Binary Insertion Sort)的基本思想是将新记录插入到已经 ...

  7. 直接插入排序(Straight Insertion Sort)的C语言实现

    原创文章,转载请注明来自钢铁侠Mac博客http://www.cnblogs.com/gangtiexia   直接插入排序(Straight Insertion Sort)的基本思想是将新记录插入到 ...

  8. 数据结构C语言版 表插入排序 静态表

    数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./*  数据结构C语言版 表插入排序  算法10.3 P267-P270  编译 ...

  9. 深入浅出数据结构C语言版(16)——插入排序

    从这一篇博文开始,我们将开始讨论排序算法.所谓排序算法,就是将给定数据根据关键字进行排序,最终实现数据依照关键字从小到大或从大到小的顺序存储.而这篇博文,就是要介绍一种简单的排序算法--插入排序(In ...

  10. C语言学习之插入排序

    此前的一些博文分别写了C语言中经典的排序方式,选择排序 冒泡排序 桶排序,此文就写 插入排序吧. 相对于冒泡排序,插入排序就比较方便快捷了.和冒泡 选择排序一样,插入排序也需要比较大小.可以这样理解插 ...

随机推荐

  1. 使用qt的hostInfo类,查看本机的IP和设备

    创建NetWorkInformation类,main.cpp直接生成. #include "networkinformation.h" #include <QApplicat ...

  2. 图解:TCP协议中的三次握手和四次挥手

    建立TCP需要三次握手才能建立,而断开连接则需要四次握手.整个过程如下图所示: 先来看看如何建立连接的. 首先Client端发送连接请求报文,Server段接受连接后回复ACK报文,并为这次连接分配资 ...

  3. ego network的概念

    转:http://greatpowerlaw.wordpress.com/2013/01/05/ego-network/ 所谓的ego network,它的节点是由唯一的一个中心节点(ego),以及这 ...

  4. Path模块部分常用函数解析——NodeJS

    官网地址:https://nodejs.org/api/path.html path.resolve([...paths])# Added in: v0.3.4 参数[...paths]: <S ...

  5. ctrl + alt + o 快速删除掉没有使用的 import

    ctrl + alt + o  优化导入,可以快速删除掉没有使用的 import

  6. 四·安装mysql-5.7.16-linux-glibc2.5-x86_64.tar.gz(基于Centos7源码安装)

    1.在Linux中创建用户mysql和主目录,并创建密码 2.解压缩tar.gz并拷贝到/usr/local/mysql目录下面 3.把/usr/local/mysql文件夹拥有者改为mysql 进入 ...

  7. 调整home和根分区大小

    目标:将VolGroup-lv_home缩小到100G,并将剩余的空间添加给VolGroup-lv_root ============================================= ...

  8. (第二场)D Money 【dp\贪心】

    题目:https://www.nowcoder.com/acm/contest/140/D 题目描述: White Cloud has built n stores numbered from 1 t ...

  9. c#用链表来存储并读取写好的配置文件

    别用arraylist,效果没有list好(因为要装箱拆箱,所以会影响性能) 使用list,那我们就来先声明一个List 1) 声明 List<元素类型> myList = new Lis ...

  10. mysql忘记密码重置密码方法

    https://blog.csdn.net/weidong_y/article/details/80493743