国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - python編程實現歸并排序

python編程實現歸并排序

2020-09-29 10:01piperck Python

這篇文章主要為大家詳細介紹了python編程實現歸并排序的具體代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

因為上個星期leetcode的一道題(Median of Two Sorted Arrays)所以想仔細了解一下歸并排序的實現。

還是先闡述一下排序思路:

首先歸并排序使用了二分法,歸根到底的思想還是分而治之。拿到一個長數組,將其不停的分為左邊和右邊兩份,然后以此遞歸分下去。然后再將她們按照兩個有序數組的樣子合并起來。這樣說起來可能很難理解,于是給出一張我畫的圖。

python編程實現歸并排序

這里顯示了歸并排序的第一步,將數組按照middle進行遞歸拆分,最后分到最細之后再將其使用對兩個有序數組進行排序的方法對其進行排序。

兩個有序數組排序的方法則非常簡單,同時對兩個數組的第一個位置進行比大小,將小的放入一個空數組,然后被放入空數組的那個位置的指針往后 移一個,然后繼續和另外一個數組的上一個位置進行比較,以此類推。到最后任何一個數組先出棧完,就將另外i一個數組里的所有元素追加到新數組后面。

由于遞歸拆分的時間復雜度是logN 然而,進行兩個有序數組排序的方法復雜度是N該算法的時間復雜度是N*logN 所以是NlogN。

根據這波分析,我們可以看看對上圖的一個行為。

當最左邊的分到最細之后無法再劃分左右然后開始進行合并。

第一次組合完成[4, 7]的合并

第二次組合完成[4, 7, 8]的合并

第三次組合完成[3, 5]的合并

第四次組合完成[3, 5, 9]的合并

第五次組合完成[3, 4, 5, 7, 8, 9]的合并結束排序。

下面放上python的代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
def merge(a, b):
 c = []
 h = j = 0
 while j < len(a) and h < len(b):
  if a[j] < b[h]:
   c.append(a[j])
   j += 1
  else:
   c.append(b[h])
   h += 1
 
 if j == len(a):
  for i in b[h:]:
   c.append(i)
 else:
  for i in a[j:]:
   c.append(i)
 
 return c
 
 
def merge_sort(lists):
 if len(lists) <= 1:
  return lists
 middle = len(lists)/2
 left = merge_sort(lists[:middle])
 right = merge_sort(lists[middle:])
 return merge(left, right)
 
 
if __name__ == '__main__':
 a = [4, 7, 8, 3, 5, 9]
 print merge_sort(a)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产天堂网| 日韩视频免费看 | 日韩精品亚洲一区 | 羞羞网站 | 久久免费精品 | 韩日一区| 亚洲一区二区精品 | av软件在线 | 欧美日韩第一页 | 亚洲精品乱码 | 91精品久久久久久久久久久 | 精品久 | 欧美在线影院 | 在线中文字幕视频 | 午夜免费在线 | 日日久| 在线观看成人 | 精品久久久久久国产 | 欧美区国产 | 免费羞羞视频网站 | 九一精品国产 | 九九亚洲 | 在线99热| 国产精品1区 | 一级久久久| 国产999免费视频 | 爱综合 | 日韩在线成人av | 超碰免费成人 | 免费观看日本视频 | 国产欧美精品一区二区三区四区 | 欧美另类专区 | 精品免费视频 | 亚洲视频在线观看 | 亚洲黄色片免费看 | 成人永久免费视频 | 日韩一级片 | 在线视频 中文字幕 | 亚洲在线精品视频 | 一区二区三区四区国产 | 国产成人精品一区二 |