您好,登錄后才能下訂單哦!
本篇內容主要講解“leetcode如何分隔鏈表”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“leetcode如何分隔鏈表”吧!
給你一個鏈表和一個特定值 x ,請你對鏈表進行分隔,使得所有小于 x 的節點都出現在大于或等于 x 的節點之前。
你應當保留兩個分區中每個節點的初始相對位置。
示例:
輸入:head = 1->4->3->2->5->2, x = 3
輸出:1->2->2->4->3->5
創建兩個鏈表,一個存放小于x的,一個存放大于x的,順序不動,最后將兩個鏈表進行拼接即可。
# 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)
到此,相信大家對“leetcode如何分隔鏈表”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。