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

歡迎訪問 生活随笔!

生活随笔

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

python

python 多个列表合并_Python对两个有序列表进行合并和排序的例子

發布時間:2023/12/15 python 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 多个列表合并_Python对两个有序列表进行合并和排序的例子 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Python對兩個有序列表進行合并和排序的例子

這篇文章主要介紹了Python對兩個有序列表進行合并和排序的例子,最終代碼經過不斷優化,小編非常滿意,需要的朋友可以參考下

假設有2個有序列表l1、l2,如何效率比較高的將2個list合并并保持有序狀態,這里默認排序是正序。

思路是比較簡單的,無非是依次比較l1和l2頭部第一個元素,將比較小的放在一個新的列表中,以此類推,直到所有的元素都被放到新的列表中。

考慮2個列表l1 = [2], l2 = [1],如何將他們合并呢?(注意:下面實現會改變l1和l2本來的值)

代碼如下:

def signle_merge_sort(l1, l2):

tmp = []

if l1[0] < l2[0]:

tmp.append(l1[0])

tmp.extend(l2)

del l2[0]

else:

tmp.append(l2[0])

tmp.extend(l1)

del l1[0]

return tmp

這真的只能處理一個元素的情形,還不能解決問題,不過好歹我們有一個大概的思路了。如果有列表中2個元素,上面的方法就不行了。我們需要解決邊界判斷問題,即當l1或者l2有一個為空的時,將剩下的一個list加到排序結果的尾部。然后確保函數每次調用只處理一個元素,通過遞歸來解決問題。

代碼如下:

def recursion_merge_sort1(l1, l2):

tmp = []

if len(l1) == 0:

tmp.extend(l2)

return tmp

elif len(l2) == 0:

tmp.extend(l1)

return tmp

else:

if l1[0] < l2[0]:

tmp.append(l1[0])

del l1[0]

else:

tmp.append(l2[0])

del l2[0]

tmp += recursion_merge_sort1(l1, l2)

return tmp

上面的程序有2個問題:if判斷太多;每次都要初始化tmp,對內存使用似乎不太友好。考慮到程序在l1或者l2有一個為空的時候就終止,可以稍微改寫一下:

代碼如下:

def _recursion_merge_sort2(l1, l2, tmp):

if len(l1) == 0 or len(l2) == 0:

tmp.extend(l1)

tmp.extend(l2)

return tmp

else:

if l1[0] < l2[0]:

tmp.append(l1[0])

del l1[0]

else:

tmp.append(l2[0])

del l2[0]

return _recursion_merge_sort2(l1, l2, tmp)

def recursion_merge_sort2(l1, l2):

return _recursion_merge_sort2(l1, l2, [])

但是對于Python而言,即使是尾遞歸,效率也不是那么高,為了避免爆棧,通常還是會用循環來做,再稍微改寫一下:

代碼如下:

def loop_merge_sort(l1, l2):

tmp = []

while len(l1) > 0 and len(l2) > 0:

if l1[0] < l2[0]:

tmp.append(l1[0])

del l1[0]

else:

tmp.append(l2[0])

del l2[0]

tmp.extend(l1)

tmp.extend(l2)

return tmp

今天栽了個坑,好好反省,就是這樣。

完 謝謝觀看

總結

以上是生活随笔為你收集整理的python 多个列表合并_Python对两个有序列表进行合并和排序的例子的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 在线免费观看日韩视频 | 777米奇影视第四色 五月丁香久久婷婷 | 成人免费视频国产在线观看 | 久久高清国产 | 亚洲69av| 日本视频免费看 | 亚洲福利视频一区二区 | 人操人视频 | 亚洲论理 | 久久人妻少妇嫩草av无码专区 | 精品人妻一区二区三区日产 | 国外成人在线视频 | 午夜影院 | 国产免费自拍视频 | 精品国产户外野外 | 黄色免费视频观看 | 91久久综合精品国产丝袜蜜芽 | 一区二区三区视频网站 | 日韩免费av在线 | 美女扒开尿口让男人爽 | 久久艹艹| 人与动物2免费观看完整版电影高清 | 色不卡| 日本欧美一区二区 | 超碰伊人久久 | 欧美福利一区二区 | 欧美高清视频一区二区三区 | 欧美日韩精品在线视频 | 色偷偷免费费视频在线 | 天天摸夜夜添 | 国产女无套免费视频 | 欧美一区二区在线播放 | 2022av视频 | 久久久涩 | 亚洲一区二区黄片 | 午夜av免费观看 | 国产日韩欧美视频 | 爱情岛亚洲品质自拍极速福利网站 | 污视频免费在线观看网站 | 自拍99| 97人妻天天摸天天爽天天 | 精精国产xxxx视频在线 | 欧美激情另类 | 天堂网一区二区三区 | 国产精品久久综合视频 | 天堂av手机版 | 人与禽性7777777 | 国产精品视频福利 | a级黄片毛片 | 波多野结衣电车痴汉 | 欧美瑟瑟 | 亚洲免费福利 | 日韩三区在线 | 韩国日本中文字幕 | 国产精品二区一区 | 亚洲在线免费观看视频 | 免费在线观看黄 | 东北少妇高潮抽搐 | 三级在线看中文字幕完整版 | 亚洲成人精品在线 | 国产精品色婷婷99久久精品 | 日本三级视频在线观看 | 亚洲av成人精品午夜一区二区 | 亚洲成人偷拍 | 久久av导航| 星空大象在线观看免费播放 | 国产综合精品视频 | 韩国19主播内部福利vip | 自拍偷拍第一页 | 国产日韩视频在线观看 | 欧美xxxx吸乳 | 天天干天天日 | 亚洲成人免费在线视频 | 五月丁香花 | 亚洲国产成人91porn | 自拍偷拍 国产 | 夜色在线视频 | 国产三级麻豆 | 免费黄网在线看 | a成人在线 | 人妻久久久一区二区三区 | 小视频在线 | 特大黑人娇小亚洲女mp4 | 国产调教视频 | 日本高清网站 | а√天堂8资源在线官网 | 朝桐光av一区二区三区 | 一级黄色小视频 | 天天看天天摸天天操 | 丰满少妇大力进入 | 古装做爰无遮挡三级聊斋艳谭 | 动漫涩涩免费网站在线看 | 国产豆花视频 | 伊人久久大香 | 可以看的毛片 | 亚洲精品视频导航 | 国产精品久久久久久久久岛 | 一区三区视频 | 91免费黄视频|