Problem:
输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空
Intuition:
第一反应是这道题需要做吗?不就从头到尾复制一遍就完事了吗?但是我们要注意链表里面的节点需要指向下一个节点,那这里就出现问题,不能直接复制了。因为你肯定不能直接指向原链表的节点进行复制。
Solution:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
| public class CodingInterview_035 {
public class RandomListNode { int label; RandomListNode next = null; RandomListNode random = null;
RandomListNode(int label) { this.label = label; } }
public RandomListNode Clone(RandomListNode pHead) { if(pHead == null) { return null; }
RandomListNode currentNode = pHead; while(currentNode != null){ RandomListNode cloneNode = new RandomListNode(currentNode.label); RandomListNode nextNode = currentNode.next; currentNode.next = cloneNode; cloneNode.next = nextNode; currentNode = nextNode; }
currentNode = pHead; while(currentNode != null) { currentNode.next.random = currentNode.random==null?null:currentNode.random.next; currentNode = currentNode.next.next; }
currentNode = pHead; RandomListNode pCloneHead = pHead.next; while(currentNode != null) { RandomListNode cloneNode = currentNode.next; currentNode.next = cloneNode.next; cloneNode.next = cloneNode.next==null?null:cloneNode.next.next; currentNode = currentNode.next; }
return pCloneHead; } }
|