希尔排序是希尔(DonaldShell)于1959年提出的一种排序算法。希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,同时该算法是冲破O(n2)的第一批算法之一。本文会以图解的方式详细介绍希尔排
插入排序分为两种:直接插入排序&希尔排序
希尔排序
1.基本思想
希尔排序是在直接插入排序基础上的优化,属于非常牛掰的一个排序。
核心思想:
- 先进行预排序,让数组接近有序;
- 直接插入排序
预排序
预排序步骤:
分组排,假设gap==3,间隔为gap的为一组,然后分别使用插入排序的思想对这gap组数据进行排序
多组间隔为gap的预排序,gap由大变小,gap越大,大的数可以越快的到后面,小的数可以越快得到前面,gap越大,预排完越不接近有序,gap越小,预排完越接近有序,gap为1时就是直接插入排序
动图演示:
预排序代码:
for (int i = 0; i < gap; i++)//有gap组需要排
{
for (int j = i; j < n - gap; j += gap)//内层循环,先排红,再排绿,最后排蓝
//注意内层循环的写法
{
//跟直接插入排序很像,不同的是需要使用gap
int end = j;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
}
这是最初的写法,其实这个代码是可以优化的:
//预排序优化
for (int i = 0; i < n - gap; i++)
//把间隔为gap的多组数据同时排
//当到n-gap-1的位置就终止了
{
int end = i;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
2.算法实现
//希尔排序
void ShellSort(int* a, int n)
{
//一开始初始化gap为n
int gap = n;
while (gap > 1)//gap大于1都是预排序,gap==1时为直接插入排序
{
//为保证gap最终结果为1,可以gap/=2,也可以是gap=gap/3+1;
gap /= 2;
//预排序优化
for (int i = 0; i < n - gap; i++)
//把间隔为gap的多组数据同时排
//当到n-gap-1的位置就终止了
{
int end = i;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
}
}
完整代码:
3.时间复杂度
希尔排序的时间复杂度是:O(N*logN)
到此这篇关于C++深入浅出讲解希尔排序算法的实现的文章就介绍到这了,更多相关C++希尔排序内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
沃梦达教程
本文标题为:C++深入浅出讲解希尔排序算法的实现
基础教程推荐
猜你喜欢
- C++详细实现完整图书管理功能 2023-04-04
- C++使用easyX库实现三星环绕效果流程详解 2023-06-26
- 详解c# Emit技术 2023-03-25
- C++中的atoi 函数简介 2023-01-05
- C语言 structural body结构体详解用法 2022-12-06
- C利用语言实现数据结构之队列 2022-11-22
- 一文带你了解C++中的字符替换方法 2023-07-20
- C/C++编程中const的使用详解 2023-03-26
- 如何C++使用模板特化功能 2023-03-05
- C语言基础全局变量与局部变量教程详解 2022-12-31