插入排序也是最简单的一类排序方法,我今天介绍的也是插入排序里最直观且浅显易懂的直接插入排序。对这个很简单的排序,记得当时也是花了近两个晚上才搞懂它的原理的,接下来就来介绍一下
插入排序分为两种:直接插入排序&希尔排序
直接插入排序
1.基本思想
直接插入排序是一种简单的插入排序算法,其基本思想是:
把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。
说得通俗一点就是:
假设区间[0, end]有序,将end+1位置的值插入到[0, end]中,保持区间[0, end+1]依旧有序。
生活中我们玩扑克牌时,就用了插入排序的思想。
在这里,我们以排升序为例。
核心思想:摸牌的过程
动图演示:
2.算法实现
写排序时,先从单趟开始考虑
//[0, end]已经有序,将end+1位置的值插入到[0,end]中,使得[0,end+1]依旧保持有序
//有一个有序区间,插入一个数据,依旧保持有序
void InsertSort(int* a, int n)
{
for (int i = 0; i < n - 1; i++)
//控制摸牌的过程,一开始从仅一张开始
//注意循环结束条件,只需要到n-2的位置,若将其改成i<n,则会出现越界的情况
{
int end = i;
int tmp = a[end + 1];
while (end >= 0)//保证牌是有序的
{
if (a[end] > tmp)
{
a[end + 1] = a[end];//往后挪,注意画图感受哦
end--;
}
else
//有两种可能:(现想常规的,再考虑特殊情况)
//一是找到了比它小的数,放到其后;
//二是没有比它小的数,直到end为-1才结束
{
break;
}
}
a[end + 1] = tmp;
}
}
完整代码:
3.时间复杂度
直接插入排序时间复杂度是O(N^2),注意哦,不是因为双重循环,需要实际计算来得出时间复杂度。
最坏情况:逆序有序,1+2+3+……+n - 1;O(N^2)
最好情况:顺序有序,1+1+1+……+1。O(N)
到此这篇关于C语言深入浅出讲解直接插入排序算法的实现的文章就介绍到这了,更多相关C语言直接插入排序内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:C语言深入浅出讲解直接插入排序算法的实现
- C++ 数据结构超详细讲解顺序表 2023-03-25
- C语言手把手带你掌握带头双向循环链表 2023-04-03
- 详解C语言中sizeof如何在自定义函数中正常工作 2023-04-09
- C语言详解float类型在内存中的存储方式 2023-03-27
- Qt计时器使用方法详解 2023-05-30
- c++ const 成员函数,返回一个 const 指针.但是返回的指针是什么类型的 const? 2022-10-11
- ubuntu下C/C++获取剩余内存 2023-09-18
- 我应该为我的项目使用相对包含路径,还是将包含目录放在包含路径上? 2022-10-30
- C语言qsort()函数的使用方法详解 2023-04-26
- Easyx实现扫雷游戏 2023-02-06