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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

python排序链表_合并K个排序链表

發(fā)布時(shí)間:2025/3/21 python 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python排序链表_合并K个排序链表 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

合并

k

個(gè)排序鏈表,返回合并后的排序鏈表。請(qǐng)分析和描述算法的復(fù)雜度。

示例:

輸入:[

1->4->5,

1->3->4,

2->6

]輸出:?1->1->2->3->4->4->5->6

#?Definition?for?singly-linked?list.#?class?ListNode(object):#?????def?__init__(self,?x):#?????????self.val?=?x#?????????self.next?=?Noneclass?Solution(object):

def?mergeKLists(self,?lists):

"""

:type?lists:?List[ListNode]

:rtype:?ListNode

"""

#合成一個(gè)大的listlist然后排序

lists?=?[x?for?x?in?lists?if?x]????????if?not?lists?or?all([not?x?for?x?in?lists]):?return

head?=?lists.pop()

curr?=?head????????while?curr.next:

curr?=?curr.next

while?lists:

tmp?=?lists.pop()

curr.next?=?tmp????????????while?tmp.next:

tmp?=?tmp.next

curr?=?tmp

if?not?head?or?not?head.next:?return?head????????return?self.mergeSort(head)

def?mergeSort(self,?head):

if?not?head.next:?return?head

pre,?slow,?fast?=?None,?head,?head

while?fast?and?fast.next:

prev,?slow,?fast?=?slow,?slow.next,?fast.next.next

prev.next?=?None

left?=?self.mergeSort(head)

right?=?self.mergeSort(slow)????????return?self.merge(left,?right)

def?merge(self,?left,?right):

if?not?left:????????????return?right????????if?not?right:????????????return?left

if?left.val?

res?=?left

res.next?=?self.merge(left.next,?right)????????else:

res?=?right

res.next?=?self.merge(left,?right.next)????????return?res

總結(jié)

以上是生活随笔為你收集整理的python排序链表_合并K个排序链表的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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