八大排序之希尔排序
来源:互联网 发布:古代中国人身高知乎 编辑:程序博客网 时间:2024/05/16 15:37
1、算法介绍:
希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
2、算法思想:
希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
2、算法思想:
算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每组中再进行直接插入排序。当增量减到1时,进行直接插入排序后,排序完成。
希尔排序先比较间隔为长度一半的两个元素,交换位置。逐渐缩小间隔来实现。
- /**
- * 希尔排序
- */
- public static void shellSort(int []array){
- int length = array.length;
- int d = length / 2;
- while(d >= 1){
- int j = 0;
- for (int i = 0; i < array.length; i++) {
- int temp = array[i];
- j = i - d;
- while(j >= 0 && temp < array [j]){
- array[j+d] = array[j];
- j -= d;
- }
- array[j+d] = temp;
- }
- d /= 2;
- System.out.println("-------" + Arrays.toString(array));
- }
- }
0 0
- 八大排序之希尔排序
- 八大排序之希尔排序
- 八大排序之希尔排序
- 八大排序--希尔排序
- 八大排序算法之希尔排序
- 八大排序算法之希尔排序
- Java八大排序算法之希尔排序
- 八大排序算法 之 希尔排序(缩小增量排序)
- 八大排序学习之三希尔排序(Shell排序)
- 八大排序算法之直接插入排序和希尔排序
- 八大排序算法之(二)插入排序 希尔排序
- 八大内部排序--希尔排序
- 八大排序算法-希尔排序
- 八大排序算法之二希尔排序(C语言)
- Java提高 - 八大排序方法之希尔排序
- Java 八大排序之——希尔排序
- 八大排序算法之-希尔排序 java代码
- 八大排序之希尔排序算法-python实现
- awk 参考
- 启动hive报错:[ERROR] Terminal initialization failed; falling back to unsupported
- zoj水题分类(自己练习)
- 三种方法遍历ArrayList
- Ubuntu下automake工具的使用
- 八大排序之希尔排序
- 生成1-n的排列
- knn算法C++实现
- Mac升级到EL Capitan后Xcode6.4找不到模拟器选择按钮
- 列出{1,2,,,,n}的所有子集
- 双散列
- 安卓基于监听事件处理(一)
- 打开网络适配的两种方法
- Map集合