题目:输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)(参考https://github.com/leeguandong/Interview-code-practice-python/blob/master/剑指offer/复杂链表的复制.py)
代码:
'''
思路:1. 根据旧链表创建新链表,不去管随机的那个指针
2. 根据旧链表中的随机指针,创建新链表中的随机指针
3. 从旧链表中拆分得到新链表
32ms
5632k
'''
# -*- 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):
if pHead == None:
return None
self.CloneNodes(pHead)
self.ConnectRandomNodes(pHead)
return self.ReconnectNodes(pHead)
# 复制原始链表的每个结点, 将复制的结点链接在其原始结点的后面
def CloneNodes(self, pHead):
pNode = pHead
while pNode:
pCloned = RandomListNode(0)
pCloned.label = pNode.label
pCloned.next = pNode.next
# pCloned.random = None #不需要写这句话, 因为创建新的结点的时候,random自动指向None
pNode.next = pCloned
pNode = pCloned.next
# 将复制后的链表中的复制结点的random指针链接到被复制结点random指针的后一个结点
def ConnectRandomNodes(self, pHead):
pNode = pHead
while pNode:
pCloned = pNode.next
if pNode.random != None:
pCloned.random = pNode.random.next
pNode = pCloned.next
# 拆分链表, 将原始链表的结点组成新的链表, 复制结点组成复制后的链表
def ReconnectNodes(self, pHead):
pNode = pHead
pClonedHead = pClonedNode = pNode.next
pNode.next = pClonedHead.next
pNode = pNode.next
while pNode:
pClonedNode.next = pNode.next
pClonedNode = pClonedNode.next
pNode.next = pClonedNode.next
pNode = pNode.next
return pClonedHead
注解:
关于python对象的值传递问题的小实验
#定义类
class RandomListNode:
def __init__(self, x):
self.label = x
self.next = None
#打印结点信息
def Print_link(pHead):
# p = copy.deepcopy(pHead)
p = pHead
while p:
print('-----------------')
print('当前结点的值:',p.label)
if p.next:
print('下一个结点的值:',p.next.label)
else:
print('下一个结点为空')
print('-----------------')
p = p.next
if __name__ == '__main__':
node1 = RandomListNode(1)
node2 = RandomListNode(2)
node3 = RandomListNode(3)
node1.next = node2
node2.next = node3
node3.next = None
Print_link(node1)
#通过验证,发现python对象是通过址传递来进行赋值,可以通过node4 = copy.deepcopy(node1)来解决
node4 = node1
print('结点4的下一个结点的值',node4.next.label)
node1.next = node3
print('结点1的下一个结点的值',node1.next.label)
print('改变结点1下一个结点的指向之后:')
print('结点4的下一个结点的值',node4.next.label)
'''
输出如下
-----------------
当前结点的值: 1
下一个结点的值: 2
-----------------
-----------------
当前结点的值: 2
下一个结点的值: 3
-----------------
-----------------
当前结点的值: 3
下一个结点为空
-----------------
结点4的下一个结点的值 2
结点1的下一个结点的值 3
改变结点1下一个结点的指向之后:
结点4的下一个结点的值 3
'''
疑问:
上述结题代码中的第47行:pClonedHead = pClonedNode = pNode.next
改变pNode的值和后继指针以后,不是会影响pClonedHead的值和后继指针吗?