ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

舍友教我希尔排序(C)

2022-02-08 13:02:10  阅读:191  来源: 互联网

标签:arr end int 舍友 gap 希尔 排序


1.排序原理

        希尔排序法又称缩小增量法。希尔排序法的基本思想是:先选定一个整数,把待排序文件中所有记录分成个组,所有距离为的记录分在同一组内,并对每一组内的记录进行排序。然后,取,重复上述分组和排序的工作。当到达=1时,所有记录在统一组内排好序。

        总的来说希尔排序是插入排序的优化,当gap > 1时都是预排序,目的是让数组更接近于有序。当gap == 1时,数组已经接近有序的了,这样就会很快。这样整体而言,可以达到优化的效果。我们实现后可以进行性能测试的对比. 希尔排序的时间复杂度不好计算,因为gap的取值方法很多,导致很难去计算,因此在好些树中给出的希尔排序的时间复杂度都不固定.

        gap的取值有很多种,在这里我们用的是size/3+1.

2.代码实现

void ShellSort(int* arr,int size){//希尔排序
    int gap=size;
    while(gap>0){//gap减小到1之后为完结
         gap=gap/3+1;//gap的取值方法
         int i=gap;
         for(i;i<size;i++){//遍历
         int end=i-gap;//分组
         int tmp=arr[i];//保存arr[i]
         while(end>=0&&arr[end]>tmp){//插入排序
            arr[end+gap]=arr[end];
            end-=gap;
         }
         arr[end+gap]=tmp;
         }
         gap--;
    }
}

贴纸们给个小红心~~

标签:arr,end,int,舍友,gap,希尔,排序
来源: https://blog.csdn.net/weixin_62029250/article/details/122821662

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有