iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言插入排序
  • 194
分享到

C语言插入排序

c语言排序算法数据结构 2023-09-28 14:09:36 194人浏览 八月长安
摘要

前言: 本文主要讲解插入排序中的直接插入排序和希尔排序。 1、直接插入排序: 1.1基本思想 直接插入排序是一种简单的插入排序法,其基本思想是把待排序的数值按照大小顺序逐个插入到一个已经排好序的有序序列中,直到将所有记录插入完为止,得到一个

前言:

本文主要讲解插入排序中的直接插入排序和希尔排序。

1、直接插入排序:

1.1基本思想

直接插入排序是一种简单的插入排序法,其基本思想是把待排序的数值按照大小顺序逐个插入到一个已经排好序的有序序列中,直到将所有记录插入完为止,得到一个新的有序序列。

实际中我们玩扑克牌时,就用了插入排序的思想。

下面的图片就是插入排序的整体过程,第一步认为5是一个有序区间,然后2比5小,就让5向后移,前面填充2,又形成一个有序的序列,以此类推……

原码:

外层的循环相当于每次插入的扑克牌,内层循环决定了这张扑克牌怎么插,插在哪里

void StraightInsert(int arr[], int n){//[0-end]有序,插入end+1位置的数,使得[0-end+1]序列仍然有序for (int i = 0;i= 0){if (arr[end] > tmp){arr[end + 1] = arr[end];end--;}elsebreak;}arr[end + 1] = tmp;}}

时间复杂度:

时间复杂度计算的是完成程序的次数不能只看是双层循环就 武断 O(N^2)

前面讲过时间复杂度计算的是最差的情况,最差的情况就是将逆序的排成升序的,1+2+3+……n-1,这是一共累加的次数,求和发现这是一个等差数列求和,最高项就是N^2,因此时间复杂度就是O(N^2)

最好的情况下本来就是顺序,end位置的值都需要跟前面一个比较,所以就是O(N)。

2、希尔排序

2.1概念:

希尔排序是一种特殊的直接插入排序,也算是直接插入排序的优化版本。

2.2思想:

我们发现在一些直接插入排序的例子时,发现其实一些排序是很接近O(N)。

比如1,2,5,3,6

因此我们想先进行预排序(让原来的排序更接近有序),接着再进行直接插入排序

2.3预排序

何为预排序?

预排序就是分组排,间隔为gap的为一组,注意 组数==gap的值

预排序的规律:(重要)

  • 多组间隔为gap的预排序,gap从大到小
  • gap越大:大的数可以越快的到后面,小的数可以越快的到前面。
  • gap越大,预排序越不接近有序
  • gap越小,预排序越接近有序
  • gap==1时,就是直接插入排序。

那gap到底是多少呢?

这个问题较难回答,这个问题没有官方的答案。

首先gap不可能是一个固定的数,应该数组的长度n相关,我们一般采用gap ==  n/ 2的表达式来去定义gap的值,因为要保证最后gap要被除到1为止

原码:

void ShellSort(int arr[], int n){int gap = n;while (gap > 1){gap = gap / 3+1;for (int i = 0; i < n - gap; i++)//这里的循环判断条件也很有讲究,正好能将多组gap排完{int end = i;int tmp = arr[end + gap];while (end >= 0){if (tmp < arr[end]){arr[end + gap] = arr[end];//将数据往后移end -= gap;}elsebreak;}arr[end + gap] = tmp;}}}

通过代码,我们不难发现预排序大部分的代码内容与直接插入排序是一样的,只不过将1换成了gap而已

预排序需要排很多次,真的比直接插入排序快嘛?

我们自己可以比较这两种排序方式上的时间差距,经过比较我们发现,直接插入排序的时间要比希尔排序的时间多上100倍左右!(随着N的增大,时间差也会增大)

时间复杂度

首先外层的while循环执行的次数是logN,内层的循环当gap很大时,执行次数是N,当gap很小时,执行次数也接近于N,所以最终的时间复杂度O(logN*N)

注意N^2与N*logN两者并不是一个量级的,特别是当N的数非常大时。

一些书上直接给出了结论O(N^1.3)。

来源地址:https://blog.csdn.net/hanwangyyds/article/details/132673260

--结束END--

本文标题: C语言插入排序

本文链接: https://www.lsjlt.com/news/420208.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言插入排序
    前言: 本文主要讲解插入排序中的直接插入排序和希尔排序。 1、直接插入排序: 1.1基本思想 直接插入排序是一种简单的插入排序法,其基本思想是把待排序的数值按照大小顺序逐个插入到一个已经排好序的有序序列中,直到将所有记录插入完为止,得到一个...
    99+
    2023-09-28
    c语言 排序算法 数据结构
  • C语言常见排序算法之插入排序(直接插入排序,希尔排序)
    目录前言一、直接插入排序1.1 基本思想1.2 算法思想1.3 程序实现1.4 直接插入排序的总结二、希尔排序2.1 算法思想2.2 程序实现2.3 希尔排序的特征总结前言...
    99+
    2024-04-02
  • C语言直接插入排序算法
    目录1.算法模板2.算法介绍3.实例总结1.算法模板 void InsertSort(SqList *L) { int j; for (int i = 2; i &l...
    99+
    2024-04-02
  • C语言中如何实现插入排序
    这篇文章主要讲解了“C语言中如何实现插入排序”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中如何实现插入排序”吧!程序代码:#include <stdio.h>&...
    99+
    2023-06-16
  • C语言直接插入排序算法介绍
    目录前言一、什么是直接插入排序二、代码讲解总结前言 直接 插入排序 (Straight Insertion Sort)是一种最简单的排序方法,其基本操作是将一条记录插入到已排好的有序...
    99+
    2024-04-02
  • C语言直接插入排序与希尔排序如何使用
    这篇文章主要讲解了“C语言直接插入排序与希尔排序如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言直接插入排序与希尔排序如何使用”吧!一.直接插入排序1.1直接插入排序引入排序是我...
    99+
    2023-06-30
  • C语言直接插入排序算法是什么
    这篇文章将为大家详细讲解有关C语言直接插入排序算法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.算法模板void InsertSort(SqList *L){&...
    99+
    2023-06-26
  • C语言中的直接插入排序(带图详细)
    目录什么是直接插入排序?算法思想实例讲解算法分析时间复杂度空间复杂度稳定性代码实现运行结果总结什么是直接插入排序? 直接插入排序是一种最简单的排序方法,其基本操作是将需要排序的元素插...
    99+
    2022-12-27
    C语言排序 C语言直接插入排序 C直接插入排序
  • C语言之直接插入排序算法的方法
    目录一、什么是直接插入排序二、代码讲解总结 直接 插入排序 (Straight Insertion Sort)是一种最简单的排序方法,其基本操作是将一条记录插入到已排好的有序表中,从...
    99+
    2024-04-02
  • 插入排序/折半插入排序
    插入排序/折半插入排序 插入排序 插入排序(英语:Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入...
    99+
    2023-10-07
    排序算法 算法 java
  • C语言二叉排序树的创建,插入和删除
    目录一、二叉排序树(二叉查找树)的概念二、二叉排序树的判别三、二叉排序树的创建(creat、insert)四、二叉排序树的插入五、二插排序树的删除六、完整代码(可以运行)总结一、二叉...
    99+
    2024-04-02
  • C语言深入探究直接插入排序与希尔排序使用案例讲解
    目录一.直接插入排序1.1直接插入排序引入1.2直接插入排序的核心思想与算法分析1.3实例说明1.4直接插入排序代码实现1.5直接插入排序性能分析二.希尔排序2.1希尔排序引入2.2...
    99+
    2024-04-02
  • C语言排序方法(冒泡,选择,插入,归并,快速)
    目录1.冒泡排序2.选择排序3.插入排序4.归并排序5.快速排序总结1.冒泡排序 它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序错误就把他们交换过来。走访元素的工作是...
    99+
    2024-04-02
  • c语言入门3(冒泡排序)
    #include <stdio.h> struct student //结构体 {char name[21];char score;};int ma...
    99+
    2023-06-03
  • C语言排序之 堆排序
    目录前言:完全二叉树在数组中下标换算公式代码工作流程整体流程重建堆函数流程大小顶堆使用场景时间复杂度代码前言: 堆是具有以下性质的完全二叉树 每个节点大于或等于其左右子节点,此时称为...
    99+
    2024-04-02
  • C语言深入浅出讲解直接插入排序算法的实现
    目录直接插入排序1.基本思想2.算法实现3.时间复杂度插入排序分为两种:直接插入排序&希尔排序 直接插入排序 1.基本思想 直接插入排序是一种简单的插入排序算法,其基本思想是...
    99+
    2024-04-02
  • C#算法之冒泡排序、插入排序、选择排序
    冒泡排序法 是数组等线性排列的数字从大到小或从小到大排序。 以从小到大排序为例。 数据 11, 35, 39, 30, 7, 36, 22, 13, 1, 38, 26, 18, 1...
    99+
    2024-04-02
  • 插入排序算法之希尔排序+直接插入排序
    目录希尔排序一、直接插入排序1. 单趟排序2. 直接插入排序二、希尔排序三、测试希尔排序和直接插入排序性能希尔排序 在介绍希尔排序之前,先了解一下直接插入排序 一、直接插入排序 1....
    99+
    2024-04-02
  • C语言八大排序之堆排序
    目录前言一、堆排序的概念二、堆排序的实现第一步:构建堆第二步:排序三、完整代码四、证明建堆的时间复杂度 前言 本章我们来讲解八大排序之堆排序。2022,地球Online新赛季开始了!...
    99+
    2024-04-02
  • C#实现冒泡排序和插入排序算法
    1.选择排序(冒泡排序) 升序 用第一个元素跟其他元素比较,如果该元素比其他元素,则交换,保证该元素是最小的。然后再用第二个元素跟后面其他的比较,保证第二个元素是除第一个最小的。依次...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作