欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JAVA十大排序算法之希爾排序詳解

 更新時間:2021年08月23日 09:51:09   作者:阿粵Ayue  
這篇文章主要介紹了java中的希爾排序,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

希爾排序

一種基于插入排序的快速的排序算法。簡單插入排序對于大規(guī)模亂序數組很慢,因為元素只能一點一點地從數組的一端移動到另一端。例如,如果主鍵最小的元素正好在數組的盡頭,要將它挪到正確的位置就需要n-1次移動。

希爾排序為了加快速度簡單地改進了插入排序,也稱為縮小增量排序。

希爾排序是把待排序數組按一定的數量分組,對每組使用直接插入排序算法排序;然后縮小數量繼續(xù)分組排序,隨著數量逐漸減少,每組包含的元素越來越多,當數量減至 1 時,整個數組恰被分成一組,排序便完成了。這個不斷縮小的數量,就構成了一個增量序列,這里的數量稱為增量。

image-20210729135834646

代碼實現

public class ShellSort {

    public static final int[] ARRAY = {12, 9, 6, 11, 5, 1, 14, 2, 10, 4, 8, 7, 13, 3};

    public static int[] sort(int[] array) {
        int len = array.length;
        if (len < 2) {
            return array;
        }
        //當前待排序數據,該數據之前的已被排序
        int current;
        //增量
        int gap = len / 2;
        while (gap > 0) {
            for (int i = gap; i < len; i++) {
                current = array[i];
                //前面有序序列的索引
                int index = i - gap;
                while (index >= 0 && current < array[index]) {
                    array[index + gap] = array[index];
                    //有序序列的下一個
                    index -= gap;
                }
                //插入
                array[index + gap] = current;
            }
            //int相除取整
            gap = gap / 2;
        }
        return array;
    }


    public static void print(int[] array) {
        for (int i : array) {
            System.out.print(i + "  ");
        }
        System.out.println("");
    }

    public static void main(String[] args) {
        print(ARRAY);
        System.out.println("============================================");
        print(sort(ARRAY));
    }
}

時間復雜度

希爾排序的復雜度和增量序列有關。

在先前較大的增量下每個子序列的規(guī)模都不大,用直接插入排序效率都較高,盡管在隨后的增量遞減分組中子序列越來越大,由于整個序列的有序性也越來越明顯,則排序效率依然較高。

從理論上說,只要一個數組是遞減的,并且最后一個值是1,都可以作為增量序列使用。有沒有一個步長序列,使得排序過程中所需的比較和移動次數相對較少,并且無論待排序列記錄數有多少,算法的時間復雜度都能漸近最佳呢?但是目前從數學上來說,無法證明某個序列是最好的。

常用的增量序列:

  • 希爾增量序列 :{n/2, (n / 2)/2, …, 1},其中N為原始數組的長度,這是最常用的序列,但卻不是最好的
  • Hibbard序列:{2k-1, …, 3,1}
  • Sedgewick序列:{… , 109 , 41 , 19 , 5,1} 表達式為9 * 4i- 9 * 2i + 1,i = 0,1,2,3,4…

算法穩(wěn)定性

由于多次插入排序,我們知道一次插入排序是穩(wěn)定的,不會改變相同元素的相對順序,但在不同的插入排序過程中,相同的元素可能在各自的插入排序中移動,如數組5,2,2,1,第一次排序第一個元素5會和第三個元素2交換,第二個元素2會和第四個元素1交換,原序列中兩個2的相對前后順序就被破壞了,所以希爾排序是一個不穩(wěn)定的排序算法。

image-20210729165300142

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • 如何在IDEA運行spark程序(搭建Spark開發(fā)環(huán)境)

    如何在IDEA運行spark程序(搭建Spark開發(fā)環(huán)境)

    spark程序可以通過pom.xml的文件配置,添加spark-core依賴,可以直接在IDEA中編寫spark程序并運行結果,這篇文章主要介紹了如何在IDEA運行spark程序(搭建Spark開發(fā)環(huán)境),需要的朋友可以參考下
    2024-02-02
  • Java異常的幾個謎題_動力節(jié)點Java學院整理

    Java異常的幾個謎題_動力節(jié)點Java學院整理

    本文給大家收藏整理java異常的幾個謎題,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-06-06
  • java單例五種實現模式解析

    java單例五種實現模式解析

    這篇文章主要介紹了java單例五種實現模式解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • 淺析Java中的繼承與組合

    淺析Java中的繼承與組合

    本文將介紹組合和繼承的概念及區(qū)別,并從多方面分析在寫代碼時如何進行選擇。文中通過示例代碼介紹的很詳細,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • Javassist如何操作Java 字節(jié)碼

    Javassist如何操作Java 字節(jié)碼

    這篇文章主要介紹了Javassist如何操作Java 字節(jié)碼,幫助大家更好的理解和學習Java,感興趣的朋友可以了解下
    2020-09-09
  • Java?Map雙列集合使代碼更高效

    Java?Map雙列集合使代碼更高效

    這篇文章主要介紹了Java?Map雙列集合使用,使你的代碼更高效,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • Java GZIPOutputStream流壓縮文件的操作

    Java GZIPOutputStream流壓縮文件的操作

    這篇文章主要介紹了Java GZIPOutputStream流壓縮文件的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • Java實現兩個隨機數組合并進行排序的方法

    Java實現兩個隨機數組合并進行排序的方法

    本文主要介紹了Java實現兩個隨機數組合并進行排序的方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 淺談Java8新特性Predicate接口

    淺談Java8新特性Predicate接口

    這篇文章主要介紹了淺談Java8新特性Predicate接口,文中有非常詳細的代碼示例,對正在學習java的小伙伴們有很好的幫助,需要的朋友可以參考下
    2021-05-05
  • Java實現數組反轉翻轉的方法實例

    Java實現數組反轉翻轉的方法實例

    本篇文章主要介紹了Java實現數組反轉翻轉的方法實例,詳細的介紹了3種實現方法,有興趣的可以了解一下。
    2017-04-04

最新評論