java排序算法之希尔排序

希尔排序是冲破二次时间屏障的第一批算法之一。

它是通过比较相距一定间隔的元素来工作,各趟比较所用的距离随着算法的进行而减小,直到最后一趟(比较相邻元素)为止。因此希尔排序也叫缩减增量排序

希尔排序使用一个序列h1,h2,h3...hk来排序。

具体的意思是

第一趟排序比较的是相隔为hk的元素,也就是比较a[i]与a[i+hk],保证a[i]<=a[i+hk]。

第二次比较的是相隔为hk-1的元素,也就是比较a[i]与a[i+hk-1],保证a[i]<=a[i+hk-1]。

直到最后比较的是相隔之间为h1的元素。.

因此这个序列也叫增量序列,这个排序算法也叫缩减增量排序

只要h1等与1,任何增量序列都是可以的。(也就是最后一定是比较相邻之间的元素)

具体看一下java的算法实现:

package k;

import java.util.Scanner;
/**
 * 希尔排序
 * @author TangZH
 *
 */
public class ShellSort {

    public static void main(String[] args)
    {
        Scanner in=new Scanner(System.in);
        String str[]=in.nextLine().split("\\s+");

        int inter[]=new int[str.length];

        for(int i=0;i<str.length;i++)
        {
            inter[i]=Integer.valueOf(str[i]);
        }

        ShellSort(inter);

        outPut(inter);
    }

    /**
     * 希尔排序
     * @param inter
     */
    private static void ShellSort(int inter[])
    {
        for(int gap=inter.length/2;gap>0;gap/=2) //gap为hk
        {
            for(int i=gap;i<inter.length;i++)
            {
                int j=i;
                int temp=inter[i];
                for(;j>=gap && temp<inter[j-gap];j-=gap)
                    inter[j]=inter[j-gap];
                inter[j]=temp;
            }
        }
    }

    private static void outPut(int []inter)
    {
        for(int n:inter)
        {
            System.out.printf("%d ", n);
        }
    }

}

实现希尔排序的方法是SellSort(int inter[]);

接下来好好分析一下该算法的每个步骤:

假如输入的是:12      4       6        24          7        12         4          16(此时gap=4,i=4,j=4,temp=inter[4]=7)

1、

此时gap=4

那么第一次7与12比较,如果小于就互相交换。

i++,12与4比较,小于就互换,

i++, 4与6比较,小于就互换,

i++,16与24比较,小于就互换。

第一趟之后为: 7        4       4        16         12        12        6          24

2、

7        4       4        16         12        12        6          24

此时gap=2

那么第一次4与7比较,如果小于就互相交换。

4 4 7 16 12  12 6 24

i++,16与4比较,小于就互换,这里16大于4,不变

4 4 7 16 12 12 6 24

i++, 12与7比较,不变,12与4比较,不变

4 4 7 16 12 12 6 24

i++,12与16比较,小于,于是变成 4 4 7  <>   12  16  6 24,12与4比较,大于4,因此12放进16原来在的位置

4 4 7 12 12 16 6 24

同样道理比较相同颜色的元素,进行排序。

.

.

.

第二趟之后为: 4       4       6        12        7        16      12       24

.

.

.

直到gap=1

每一趟的排序结果为(输入为:12      4       6        24          7        12         4          16)

7 4 4 16 12 12 6 24

4 4 6 12 7 16 12 24

4 4 6 7 12 12 16 24

4 4 6 7 12 12 16 24

总而言之:

gap的值就是hk,元素之间的间隔,这道题中gap=4,2,1。

最外层的循环是给出gap的值.(每次都除以二),然后在循环里面开始对相隔为gap的元素进行插入排序,直到最后一趟比较相邻之间的元素。

时间: 2024-12-24 03:42:19

java排序算法之希尔排序的相关文章

排序算法之希尔排序

文章转载自http://www.cnblogs.com/chengxiao/ 希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法.希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,同时该算法是冲破O(n2)的第一批算法之一.本文会以图解的方式详细介绍希尔排序的基本思想及其代码实现. 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序:随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组

经典排序算法之希尔排序

? 希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法.希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,同时该算法是冲破O(n2)的第一批算法之一.希尔排序适合数据量中等情况,几十个到几万个. ? 网上看了好久才彻底明白希尔排序是什么,简单的说将就是按照步进对数据进行分组,对每组分别进行插入排序,直到步进是1的时候则全部完成.在此感谢 dreamcatcher-cx的博客 的讲解. function sortShell(arr)

我的Java开发学习之旅------&gt;Java经典排序算法之希尔排序

一.希尔排序(Shell Sort) 希尔排序(Shell Sort)是一种插入排序算法,因D.L.Shell于1959年提出而得名.Shell排序又称作缩小增量排序. 二.希尔排序的基本思想 希尔排序的中心思想就是:将数据进行分组,然后对每一组数据进行排序,在每一组数据都有序之后 ,就可以对所有的分组利用插入排序进行最后一次排序.这样可以显著减少交换的次数,以达到加快排序速度的目的.       希尔排序的中心思想:先取一个小于n的整数d1作为第一个增量,把文件的全部记录分成d1个组.所有距离

排序算法系列——希尔排序

希尔排序同之前介绍的直接插入排序一起属于插入排序的一种.希尔排序算法是按其设计者希尔(Donald Shell)的名字命名,该算法由1959年公布,是插入排序的一种更高效的改进版本.它的作法不是每次一个元素挨一个元素的比较.而是初期选用大跨步(增量较大)间隔比较,使记录跳跃式接近它的排序位置:然后增量缩小:最后增量为 1 ,这样记录移动次数大大减少,提高了排序效率.希尔排序对增量序列的选择没有严格规定. 希尔排序是基于插入排序的以下两点性质而提出改进方法的: 插入排序在对几乎已经排好序的数据操作

算法学习之排序算法:希尔排序

希尔排序又称"缩小增量排序",它的基本思想是:先将整个待排记录序列分割成若干子序列分别进行直接插入排序,待整个序列中的记录"基本有序"时,再对记录进行一次直接插入排序. 希尔排序的一个特点是:子序列的构成不是简单地"逐段分割",而是将相隔某个"增量"的记录组成一个子序列.这就使得希尔排序中关键字较小的记录不是一步一步地往前挪动,而是一次按照"增量"的大小跳跃式地往前移,从而使得在进行最后一趟增量为1的插入排

Java学习笔记——排序算法之希尔排序(Shell Sort)

落日楼头,断鸿声里,江南游子.把吴钩看了,栏杆拍遍,无人会,登临意. --水龙吟·登建康赏心亭 希尔算法是希尔(D.L.Shell)于1959年提出的一种排序算法.是第一个时间复杂度突破O(n2)的算法之一. 其基础是插入排序. 上代码: 1 public class ShellSort { 2 3 public static void shellSort(int[] arr){ 4 5 int increment = arr.length; 6 int temp;//牌 7 int i; 8

排序算法:希尔排序

希尔排序的实质就是分组插入排序,该方法又称缩小增量排序,因DL.Shell于1959年提出而得名. 该方法的基本思想是:先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接插入排序,然后依次缩减增量再进行排序,待整个序列中的元素基本有序(增量足够小)时,再对全体元素进行一次直接插入排序.因为直接插入排序在元素基本有序的情况下(接近最好情况),效率是很高的,因此希尔排序在时间效率上比前两种方法有较大提高. 以n=10的一个数组49, 38, 65, 97, 26,

9种排序算法 3_希尔排序

一 算法思想 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序:随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止. 二 代码如下 // 希尔排序.随机数列中(100个),计算交换次数(交换的次数在300-400左右,时间复杂度O(n的1.25次方)) 1.简化版算法,每次只交换2个数据 public static void shellSort(int[] array) { int d = array.length / 2; whil

程序员需要掌握的排序算法之希尔排序(最小增量排序)

希尔排序(最小增量排序) 基本思想:希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序:随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止. package sortalgorithm; public class PublicShellSort { static void shellSort() { int[] sortList = { 1, 3, 2, 4, 10, 7, 8, 9, 5, 6 }; int n = 1,len = s