您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“LeetCode如何實現復雜鏈表的復制”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“LeetCode如何實現復雜鏈表的復制”這篇文章吧。
請實現 copyRandomList 函數,復制一個復雜鏈表。在復雜鏈表中,每個節點除了有一個 next 指針指向下一個節點,還有一個 random 指針指向鏈表中的任意節點或者 null。
head = [[7,null],[13,0],[11,4],[10,2],[1,0]]
[[7,null],[13,0],[11,4],[10,2],[1,0]]
O(N)
O(N)
class Solution:
def copyRandomList(self, head: 'Node') -> 'Node':
if not head:
return None
maps = {}
# 第一遍遍歷, 建立新的鏈表, 以及老節點到新節點的映射關系
copyHead = Node(head.val)
origin, copy = head, copyHead
maps[origin] = copy
while origin.next:
# 新建下一個節點, 并建立next關系
copy.next = Node(origin.next.val)
origin = origin.next
copy = copy.next
maps[origin] = copy
# 第二遍遍歷, 處理random指針部分
origin, copy = head, copyHead
while origin:
if origin.random:
# 如果老節點random指針指向非空的話, 就將當前新節點也指向隨機節點對應的新節點
copy.random = maps[origin.random]
origin = origin.next
copy = copy.next
return copyHead
以上是“LeetCode如何實現復雜鏈表的復制”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。