服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C++深入浅出讲解希尔排序算法的实现

C++深入浅出讲解希尔排序算法的实现

2022-12-05 13:31安然无虞 C/C++

希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法。希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,同时该算法是冲破O(n2)的第一批算法之一。本文会以图解的方式

插入排序分为两种:直接插入排序&希尔排序

希尔排序

1.基本思想

希尔排序是在直接插入排序基础上的优化,属于非常牛掰的一个排序。

核心思想:

  • 先进行预排序,让数组接近有序;
  • 直接插入排序

预排序

预排序步骤:

分组排,假设gap==3,间隔为gap的为一组,然后分别使用插入排序的思想对这gap组数据进行排序

C++深入浅出讲解希尔排序算法的实现

多组间隔为gap的预排序,gap由大变小,gap越大,大的数可以越快的到后面,小的数可以越快得到前面,gap越大,预排完越不接近有序,gap越小,预排完越接近有序,gap为1时就是直接插入排序

动图演示:

C++深入浅出讲解希尔排序算法的实现

预排序代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
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;
    }
}

这是最初的写法,其实这个代码是可以优化的:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//预排序优化
        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.算法实现

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
//希尔排序
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;
        }
    }
}

完整代码:

C++深入浅出讲解希尔排序算法的实现

3.时间复杂度

希尔排序的时间复杂度是:O(N*logN)

C++深入浅出讲解希尔排序算法的实现

到此这篇关于C++深入浅出讲解希尔排序算法的实现的文章就介绍到这了,更多相关C++希尔排序内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://bit-runout.blog.csdn.net/article/details/124702416

延伸 · 阅读

精彩推荐
  • C/C++C语言 数据存储方式知识点详解

    C语言 数据存储方式知识点详解

    在本篇文章里小编给大家整理的是关于C语言 数据存储方式知识点详解,有需要的朋友们可以学习参考下。...

    kevin.Xiang9392021-08-20
  • C/C++如何使用C语言实现平衡二叉树数据结构算法

    如何使用C语言实现平衡二叉树数据结构算法

    对于判断是否为平衡二叉树而言,我们需要知道以下特性:是一个二叉树也是一个二叉排序树该树的每个结点上的(深度)左子树 - 右子树的值为平衡因子(...

    sehun?9912021-12-20
  • C/C++C语言实现简单的扫雷游戏操作

    C语言实现简单的扫雷游戏操作

    这篇文章主要为大家详细介绍了C语言实现简单的扫雷游戏操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    恋浅笑10552021-10-25
  • C/C++C语言动态内存管理的实现

    C语言动态内存管理的实现

    本文主要介绍了C语言动态内存管理的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    DanteIoVeYou7452021-12-21
  • C/C++C语言学习笔记之VS2022安装使用教程

    C语言学习笔记之VS2022安装使用教程

    这篇文章主要介绍了C语言学习笔记之VS2022安装使用教程,在VS2022中,在使用scanf函数编译出错,本文给大家提到了解决方法,需要的朋友可以参考下...

    一个努力成为大白的小白6562022-11-21
  • C/C++C语言中 “_at()” 特殊地址定位详解

    C语言中 “_at()” 特殊地址定位详解

    这篇文章主要介绍了C语言中 “_at()” 特殊地址定位详解的相关资料,需要的朋友可以参考下...

    木十化5872021-05-11
  • C/C++一篇文章带你了解c++运算符重载

    一篇文章带你了解c++运算符重载

    下面小编就为大家带来一篇深入理解C++运算符重载。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    三丰杂货铺6102021-12-15
  • C/C++C语言预处理详解

    C语言预处理详解

    这篇文章主要给大家介绍了关于C语言之预处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋...

    少司命11592022-01-20