91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Python中怎么實現希爾排序算法

發布時間:2023-05-11 10:56:06 來源:億速云 閱讀:247 作者:zzz 欄目:編程語言

這篇文章主要講解了“在Python中怎么實現希爾排序算法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“在Python中怎么實現希爾排序算法”吧!

    算法描述

    希爾排序,又叫“縮小增量排序”,是對插入排序進行優化后產生的一種排序算法。它的執行思路是:把數組內的元素按下標增量分組,對每一組元素進行插入排序后,縮小增量并重復之前的步驟,直到增量到達1。

    一般來說,希爾排序的時間復雜度為O(n1.3)~O(n2),它視增量大小而定。希爾排序的空間復雜度是O(1),它是一個不穩定的排序算法。進行希爾排序時,元素一次移動可能跨越多個元素,從而可能抵消多次移動,提高了效率。

    下面是使用(數組長度/2)作為初始增量的升序希爾排序,每一輪排序過后,增量都縮小一半。

    第一步:

    如圖2-28所示,從第一個元素開始,以增量4來分組。可以看出,當增量為4時,一組內只有兩個元素,否則元素的下標就超出了數組的范圍。

    在Python中怎么實現希爾排序算法

    第二步:

    如圖2-29所示,對組內的元素進行插入排序。

    在Python中怎么實現希爾排序算法

    第三步:

    如圖2-30所示,繼續用相同的方法分組,對組內的元素進行插入排序使得它們有序。

    在Python中怎么實現希爾排序算法

    整個數組內的數都被遍歷完成后,這一輪排序就結束了。把增量縮小一半,繼續進行下一輪排序。

    第四步:

    如圖2-31所示,增量為2時,可以看出每一組內的元素增多了,組的總數減少了。繼續對每一組內的元素進行插入排序,直到每一組都遍歷完成。

    在Python中怎么實現希爾排序算法

    第五步:

    最后一輪排序如圖2-32所示,再次把增量縮小一半;這時增量為1,相當于對整個數組進行插入排序,也就是最后一輪排序。

    在Python中怎么實現希爾排序算法

    最后一輪排序結束后,整個希爾排序就結束了。

    代碼實現

    在for循環中,由于每組的第一個元素不用進行插入排序,而它們的下標處于0~step-1,所以從下標step開始遍歷。

    需要注意的是,如果要模擬流程圖中的做法,要使用兩個循環:先分組,然后一次性使同組內的元素有序。為了提高效率,我們直接使用一個for循環,每遍歷到一個數,就對它所在的組進行插入排序。這樣遍歷同樣符合插入排序的順序要求。在插入排序中,要改變當前下標的值,所以使用變量ind存儲當前下標,防止影響for循環。

    普通插入排序等同于增量為1的希爾排序,跨元素的希爾排序實際上只改變了增量,邏輯上與普通插入排序沒有區別。

    希爾排序代碼:

    nums = [5,3,6,4,1,2,8,7]
    def ShellSort(nums):
      step = len(nums)//2         #初始化增量為數組長度的一半
      while step > 0:           #增量必須是大于0的整數
       for i in range(step,len(nums)): #遍歷需要進行插入排序的數
         ind = i
         while ind >= step and nums[ind] < nums[ind-step]: #對每組進行插入排序
          nums[ind],nums[ind-step] = nums[ind-step],nums[ind]
          ind -= step
       step //= 2           #增量縮小一半
      print(nums)
    ShellSort(nums)

    運行程序,輸出結果為:

    [1,2,3,4,5,6,7,8]

    感謝各位的閱讀,以上就是“在Python中怎么實現希爾排序算法”的內容了,經過本文的學習后,相信大家對在Python中怎么實現希爾排序算法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    延庆县| 伊川县| 安新县| 北票市| 镇平县| 烟台市| 亚东县| 阿巴嘎旗| 南部县| 永吉县| 洛浦县| 茌平县| 普洱| 东阳市| 崇义县| 宾阳县| 盈江县| 玛沁县| 龙江县| 吉林省| 调兵山市| 汉沽区| 宣武区| 抚宁县| 呼和浩特市| 长寿区| 龙里县| 赤壁市| 瑞安市| 松江区| 平凉市| 孝昌县| 偏关县| 松潘县| 北安市| 宜良县| 大同县| 九江市| 家居| 徐汇区| 新余市|