排序四 希尔排序
来源:互联网 发布:喇叭主升浪指标源码 编辑:程序博客网 时间:2024/06/06 08:35
希尔排序(Shell Sort)
希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。 —百度百科
时间复杂度:最好 O(n)=O(nlogn);平均O(n)=depends on gap;最差O(n)=O(n²)
空间复杂度:O(n)=O(1)
稳定性: 不稳定
算法描述
- 定义一个间隔增量gap,gap小于待排序序列长度。
- 根据增量gap将待排序序列进行分组,对每一组进行简单插入排序。
- gap减小。若gap>=1则继续执行步骤1,否则排序结束。
图片来自维基百科
排序示例
现有一个长度为10待排序数组S:[9,1,5,3,8,7,2,4,6,0]
第一次选择增量为gap=S.Length/2,以gap=gap/2的方式缩小增量
示例代码
public static void ShellSort(int[] S){ for (int gap = S.Length / 2; gap > 0; gap /= 2){ for (int i = gap; i < S.Length; i++){ for (int j = i - gap; j >= 0 && S[j] > S[j+gap]; j -= gap){ S.Swap(j, j + gap); } } }}
文中若有什么错误,欢迎留言指正。
转载请保留出处:http://blog.csdn.net/x1060549/article/details/78780085
阅读全文
0 0
- 排序四 希尔排序
- 排序四 希尔排序
- 排序(四):希尔排序
- 四、希尔排序
- 四 希尔排序
- C#算法----(四)希尔排序
- 排序算法总结(四)希尔排序
- 蛙步学排序算法之四 - 希尔排序
- 【算法-排序之四】希尔排序
- 【算法-排序之四】希尔排序
- 排序算法(四)希尔排序
- 排序算法(四)希尔排序
- 排序算法(四)- 希尔排序
- Java排序算法(四):希尔排序
- 数据结构之排序(四)希尔排序
- 排序总结系列四:希尔排序
- 排序算法四——希尔排序
- 排序算法(四) 希尔排序
- gdb和coredump
- 把数据保存到数据库附加表 `dede_addonarticle` 时出错,请把相关信息提交给DedeCms官方。Duplicate entry ’3′ for key ‘PRIMARY’
- IBM:怎样利用深度学习、机器学习等方法提高信息处理效率
- 1077. 互评成绩计算 (20) PAT乙级真题
- node.js 命令行运行的时候传参数
- 排序四 希尔排序
- Netty,Kafka,Muduo关于时间轮的一些思考 之netty时间轮
- 虽定义轻薄本,但本本之间的差别很大
- android长连接实现
- 更改eclipse项目名称后,如果有问题,
- 普元 EOS Platform 7.6 集群,同一个流程实例,不同节点在workspace中显示的状态不一致
- Android:判断应用程序接收通知开关是否打开
- Windows下安装 XGBoost (Installing XGBoost For Anaconda on Windows)
- C++ 变量类型