题目描述:
输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)
思路:(参考牛客网评论)
1. 把复制的结点链接在原始链表的每一对应结点后面


2. 把复制的结点的random指针指向被复制结点的random指针的下一个结点

3. 拆分成两个链表,奇数位置为原链表,偶数位置为复制链表,注意复制链表的最后一个结点的next指针不能跟原链表指向同一个空结点None,next指针要重新赋值None(判定程序会认定你没有完成复制)

python代码实现如下:
# -*- coding:utf-8 -*-
# class RandomListNode:
# def __init__(self, x):
# self.label = x
# self.next = None
# self.random = None
class Solution:
# 返回 RandomListNode
def Clone(self, pHead):
# write code here
if not pHead:
return None
node = pHead
while node :
copynode = RandomListNode(node.label)
copynode.next = node.next
node.next = copynode
node = copynode.next
node = pHead
while node:
copynode = node.next
if node.random:
copynode.random = node.random.next
node = copynode.next
node = pHead
copyHead = pHead.next
while node:
copynode = node.next
node.next = copynode.next
if node.next:
copynode.next = node.next.next
else:
copynode.next = None
node = node.next
return copyHead
本文介绍了一种复制复杂链表的方法,通过将复制节点插入原节点之后,再调整random指针,最后分离成两个独立链表,实现了完整复制。
2万+

被折叠的 条评论
为什么被折叠?



