码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 什么是希尔排序?


    希尔排序

    • 介绍
    • 算法实现
      • 实现方法1(我编写的我认为容易理解的希尔排序实现算法)
        • 实现效果
      • 实现方法2(网络上最常见的希尔排序算法)
      • 扩展
    • 后续

    介绍

    希尔排序又称缩小增量排序,基本思想为:先将待排序列分割成若干子表,把相隔某个增量的记录组成一个子表,对各个子表分别进行直接插入排序,当整个表已基本有序的时候,再对整个表进行一次直接插入排序。

    希尔排序的过程如下:先取一个小于n的步长d1,把表中的全部记录分成d1组,所有距离为d1的倍数的记录放在同一组,在各组内进行直接插入排序;然后取第二个步长d2 希尔排序的时间复杂度大概在O(n^1.3),在最坏的情况下会到达 O( n^2 )。

    算法实现

    实现方法1(我编写的我认为容易理解的希尔排序实现算法)

    我们初始时,令增量d为数组大小的一半,之后每次增量折半,直到小于1的时候,会停止。也就是最后一次循环时,增量为1,相当于直接插入排序,但此时因为已经基本有序,所以移动的元素非常少了。

    每个增量dt将元素分成dt组,每组的元素进行直接排序。

    
    #include 
    #include 
    #include 
    void Hill_sort(int a[],int size);
    int main()
    {
        int k;
        int num[9]={9,8,7,4,6,5,1,2,3}; 
        int sortsize=sizeof(num)/sizeof(num[0]);
        Hill_sort(num,sortsize);
        for(k=0;k<sortsize;k++)
        printf("%d\n",num[k]);
        system("pause");
        return 0;
    }
    void Hill_sort(int a[],int size)
    {
        int i,j,k;
        int d;
        int temporary;
        for(d=size/2;d>=1;d=d/2)
        {
          printf("\nd=%d:",d);
          for(k=0;k<d;k++)
            for(i=k;i<size;i+=d)
            {
                  printf("\ni=%d:",i);
                temporary=a[i];
                for(j=i-d;a[j]>temporary&&j>=0;j=j-d)
                {
                    a[j+d]=a[j];
                    printf("j=%d;",j);
                }
                a[j+d]=temporary;
             
            }
        }
    }
    
    
    

    实现效果

    在这里插入图片描述

    上述程序是我按照我的思路写的,我认为是最容易理解,但效率不是最高的,程序中使用了四重循环。

    实现方法2(网络上最常见的希尔排序算法)

    网络上最常见的希尔排序算法的实现,如下所示。

    void shell_Sort(ElemType A[],int n)
    {
    	int i, j, dk;
    	for (int dk = n / 2; dk >= 1; dk--)
    		for(int i=dk+1;i<=n;i++)
    			if (A[i] < A[i - dk])
    			{
    				A[0] = A[i];
    			}
    	for (int j = i - dk; j > 0 && A[0] < A[j]; j -= dk)
    		A[j + dk] = A[j];
    	A[j + dk] = A[0];
    }
    
    

    扩展

    数据结构或者说算法,只要理念是一样的,实现方法因人而异,我们不需要纠结到底哪一个效率最高,因为只要是按照此算法理解实现的程序,大致的算法时间复杂度都大同小异,关键是我们是否能学会此算法,而判断我们学会算法的标准就是自己能写出符合此算法思路的实现程序,如果能和网络上其他人写的不一样,反而是一种好事。所以读者可以仔细理解一下上面的两个程序,来理解一下希尔排序的理念和优点。

    后续

    欢迎关注公众号:物联网知识

  • 相关阅读:
    第100+15步 ChatGPT学习:R实现Ababoost分类
    Vue前端框架12 组件生命周期、生命周期的应用、动态组件、组件保持存活、异步组件、依赖注入、Vue应用原理
    新一代信息技术与制造业融合发展背景下网络安全挑战和思考
    c# in vs out vs ref
    第一章:认识Qt 之 1.2 Qt发展历史
    Cilium系列-16-CiliumNetworkPolicy 实战演练
    网络基础(数据链路层)
    AJAX 入门 day3
    Win10 系统中用户环境变量和系统环境变量是什么作用和区别?
    学生个人单页面网页作业 学生网页设计成品 静态HTML网页单页制作 dreamweaver网页设计与制作代码 web前端期末大作业
  • 原文地址:https://blog.csdn.net/qq_44629109/article/details/126958134
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号