八大排序之希尔排序
2016-05-12 20:57
309 查看
1、算法介绍:
希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
2、算法思想:
算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每组中再进行直接插入排序。当增量减到1时,进行直接插入排序后,排序完成。
希尔排序先比较间隔为长度一半的两个元素,交换位置。逐渐缩小间隔来实现。
[java] view
plain copy
/**
* 希尔排序
*/
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));
}
}
希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
2、算法思想:
算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每组中再进行直接插入排序。当增量减到1时,进行直接插入排序后,排序完成。
希尔排序先比较间隔为长度一半的两个元素,交换位置。逐渐缩小间隔来实现。
[java] view
plain copy
/**
* 希尔排序
*/
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));
}
}
相关文章推荐
- Error Domain=NSOSStatusErrorDomain Code=1718449215 "The operation couldn’t be completed. (OSStatus error 1718449215.)"
- SVN
- 振兴中华
- java如何使用DOM文档
- PF不明内存泄露已解决,白头发也没了(转)
- PHP 面向对象
- 云计算从服务到公共资源的演化之路
- 逻辑推断
- 列出{1,2,,,,n}的所有子集
- 安卓基于监听事件处理(一)
- 打开网络适配的两种方法
- HDU 5167(map + 暴力)
- sprint
- Ubuntu下automake工具的使用
- CentOS硬软链接
- 模拟猜数(POJ2328)
- 生成1-n的排列
- zoj水题分类(自己练习)
- awk 参考
- 三种方法遍历ArrayList