排序算法:希尔排序

在实现希尔排序的过程中,我们需要先对整个序列进行分组,然后组内进行插入排序,这样可以将元素快速的移动到大致所在的位置,然后不断减少分组的步长,最后对整个序列进行插入排序,因为此前已经将元素大跨步的移动到大致所在的位置,所以最后进行的插入排序进行比较的次数也会减小。整个希尔排序的流程大致如下所示:
先对整个序列进行分组:
在这里插入图片描述

组内进行插入排序,排序后的序列为:
在这里插入图片描述

接着缩小步长为2进行分组:
在这里插入图片描述

再进行插入排序:
在这里插入图片描述

接着缩小步长为1进行分组(即整个序列为1组):
在这里插入图片描述

对组内进行排序,对步长为1的组进行排序是在找元素的精确位置:
在这里插入图片描述

整个序列就排序完毕,这就是希尔排序的大致流程,总体思路为先大致确定元素所在的位置,再精确确定元素的位置。
代码如下:

#include<stdio.h>
#include<stdlib.h>
void shellsort(int *nums, int length){
   
    int step = length/2;
    while(step!=0){
   
        for(int i=0; i<step; i++){
   
            for(int j=i+step; j<length; j+=step){
   
                int index = j;
                for(int k=j-step; k>=0; k-=step){
   
                    if(nums[k]>nums[j]){
   
                        index = k;
                    }else{
   
                        break;
                    }
                }
                int temp = nums[j];
                for(int l=j; l>index; l-=step){
   
                    nums[l] = nums[l-step];
                }
                nums[index] = temp;
            }
        }
        step/=2;
    }
}
int main(){
   
    int * nums = NULL;
    int n;
    printf("请问你要输入多少个元素的序列:");
    scanf("%d", &n);
    nums = (int *)malloc(sizeof(int)*n);
    for(int i=0; i<n; i++){
   
        scanf("%d", nums+i);
    }
    shellsort(nums, n);
    printf("排序后的序列为:");
    for(int i=0; i<n; i++){
   
        printf("%d ", *(nums+i));
    }
    return 0;
}

运行结果:
只打印排序完成后整个序列:
在这里插入图片描述

打印出每一次分组排序后的整个序列:
在这里插入图片描述

如果有什么地方讲的不好或者讲错的地方欢迎大家指出来,如果我所讲的对你们有帮助不要忘了点赞、收藏、关注哦!


我是你们的好伙伴apprentice_eye


一个致力于让知识变的易懂的博主。

相关推荐

  1. 排序算法——排序

    2024-01-10 16:14:03       43 阅读
  2. 排序算法排序

    2024-01-10 16:14:03       35 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-10 16:14:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-10 16:14:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-10 16:14:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-10 16:14:03       20 阅读

热门阅读

  1. 安装配置Flink

    2024-01-10 16:14:03       37 阅读
  2. 脚本语言 汇总-正则表达式regexp

    2024-01-10 16:14:03       31 阅读
  3. 【算法笔记】动态规划专题

    2024-01-10 16:14:03       27 阅读
  4. ubuntu 22.04 安装r-base时缺少r-recommended

    2024-01-10 16:14:03       27 阅读
  5. 力扣103. 二叉树的锯齿形层序遍历

    2024-01-10 16:14:03       39 阅读
  6. Istio 专栏目录

    2024-01-10 16:14:03       35 阅读
  7. Python的进制转换

    2024-01-10 16:14:03       36 阅读
  8. SkyWalking相关问题及答案(2024)

    2024-01-10 16:14:03       45 阅读
  9. PCL 点云八叉树射线相交

    2024-01-10 16:14:03       39 阅读
  10. 阶乘数码#洛谷

    2024-01-10 16:14:03       63 阅读
  11. 运维工程师的困境和解困之道

    2024-01-10 16:14:03       39 阅读
  12. 八股文 c++ 多态

    2024-01-10 16:14:03       28 阅读
  13. kotlin的抽象类和抽象方法

    2024-01-10 16:14:03       33 阅读
  14. WinForm 中Label自动换行 解决方法 Label自动换行

    2024-01-10 16:14:03       36 阅读
  15. 【数组】力扣704二分查找

    2024-01-10 16:14:03       40 阅读
  16. QT 简单连接WIFI模块

    2024-01-10 16:14:03       38 阅读