本篇內(nèi)容主要講解“l(fā)eetcode如何分隔鏈表”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“l(fā)eetcode如何分隔鏈表”吧!
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:主機(jī)域名、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、舟山網(wǎng)站維護(hù)、網(wǎng)站推廣。
給你一個鏈表和一個特定值 x ,請你對鏈表進(jìn)行分隔,使得所有小于 x 的節(jié)點(diǎn)都出現(xiàn)在大于或等于 x 的節(jié)點(diǎn)之前。
你應(yīng)當(dāng)保留兩個分區(qū)中每個節(jié)點(diǎn)的初始相對位置。
示例:
輸入:head = 1->4->3->2->5->2, x = 3
輸出:1->2->2->4->3->5
創(chuàng)建兩個鏈表,一個存放小于x的,一個存放大于x的,順序不動,最后將兩個鏈表進(jìn)行拼接即可。
# Definition for singly-linked list. class ListNode: def __init__(self, x): self.val = x self.next = None def __repr__(self): return str(self.val) class Solution: def partition(self, head: ListNode, x: int) -> ListNode: if not head: return head head1 = ListNode(0) head2 = ListNode(0) cur1 = head1 cur2 = head2 while head: if head.val < x: cur1.next = head head = head.next cur1 = cur1.next cur1.next = None else: cur2.next = head head = head.next cur2 = cur2.next cur2.next = None cur1.next = head2.next return head1.next if __name__ == '__main__': s = Solution() head_list = [1, 4, 3, 2, 5, 2] head = ListNode(head_list[0]) cur = head for i in range(1, len(head_list)): cur.next = ListNode(head_list[i]) cur = cur.next x = 3 ans = s.partition(head, x) print(ans)
到此,相信大家對“l(fā)eetcode如何分隔鏈表”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!