日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python 归并排序(详解)

發(fā)布時間:2025/3/21 python 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 归并排序(详解) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、歸并排序

歸并排序(MERGE-SORT)是建立在歸并操作上的一種有效的排序算法,該算法采用經(jīng)典的分治(divide-and-conquer)策略(分治法將問題分(divide)成一些小的問題然后遞歸求解,而治(conquer)的階段則將分的階段得到的各答案"修補"在一起,即分而治之),將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序,若將兩個有序表合并成一個有序表,稱為二路歸并。

二、歸并排序的基本思想

將待排序序列R[0…n-1]看成是n個長度為1的有序序列,將相鄰的有序表成對歸并,得到n/2個長度為2的有序表;將這些有序序列再次歸并,得到n/4個長度為4的有序序列;如此反復進行下去,最后得到一個長度為n的有序序列

三、歸并排序的算法描述

第一步:申請空間,使其大小為兩個已經(jīng)排序序列之和,該空間用來存放合并后的序列
第二步:設定兩個指針,最初位置分別為兩個已經(jīng)排序序列的起始位置
第三步:比較兩個指針所指向的元素,選擇相對小的元素放入到合并空間,并移動指針到下一位置
重復步驟3直到某一指針超出序列尾,將另一序列剩下的所有元素直接復制到合并序列尾

歸并排序其實要做兩件事:
(1)“分解”——將序列每次折半劃分(遞歸實現(xiàn))

(2)“合并”——將劃分后的序列段兩兩合并后排序

如何合并?

在每次合并過程中,都是對兩個有序的序列段進行合并,然后排序。

這兩個有序序列段分別為 R[low, mid] 和 R[mid+1, high]。

先將他們合并到一個局部的暫存數(shù)組R2中,帶合并完成后再將R2復制回R中。

我們稱 R[low, mid] 第一段,R[mid+1, high] 為第二段。

每次從兩個段中取出一個記錄進行關鍵字的比較,將較小者放入R2中,最后將各段中余下的部分直接復制到R2中。

經(jīng)過這樣的過程,R2已經(jīng)是一個有序的序列,再將其復制回R中,一次合并排序就完成了。

四、拆分過程

五、代碼實現(xiàn)過程(python)

# 歸并排序 def merge_sort(num_list):length = len(num_list)# 遞歸終止退出條件if length <= 1:return num_list# 拆分mid = length // 2left_l = merge_sort(num_list[:mid]) # 對左側的列表進行排序right_l = merge_sort(num_list[mid:]) # 對右側的列表進行排序# merge 合并操作# 初始化兩個指針p, q 初始位置為起始位置,初始化一個臨時數(shù)組temp_listp, q, temp_list = 0, 0, list()len_left, len_right = len(left_l), len(right_l) # 計算當前被合并的列表的長度while len_left > p and len_right > q:if left_l[p] <= right_l[q]:temp_list.append(left_l[p])p += 1else:temp_list.append(right_l[q])q += 1# 如果left 和 right 的長度不相等,把長的部分直接追加到列表中temp_list += left_l[p:]temp_list += right_l[q:]return temp_listif __name__ == '__main__':num_list = [44, 23, 1, 14, 6, 9, 4, 5, 33]new_list = merge_sort(num_list)for k, v in enumerate(new_list):num_list[k] = vprint('num_list:', num_list)

六、時間復雜度和空間復雜度

七、輔助學習視頻資料

https://www.bilibili.com/video/BV1ZW411q7vG?p=3

總結

以上是生活随笔為你收集整理的python 归并排序(详解)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。