排序算法:希尔排序

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

先对整个序列进行分组:

组内进行插入排序,排序后的序列为:

接着缩小步长为2进行分组:

再进行插入排序:

接着缩小步长为1进行分组(即整个序列为1组):

对组内进行排序,对步长为1的组进行排序是在找元素的精确位置:

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

代码如下:

c 复制代码
#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

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

相关推荐
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮4 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说4 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove5 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung5 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了5 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL5 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰6 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商6 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug9997 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab