首页 > 代码库 > Leetcode-Copy List with Random Pointer
Leetcode-Copy List with Random Pointer
A linked list is given such that each node contains an additional random pointer which could point to any node in the list or null.
Return a deep copy of the list.
Solution:
1 /** 2 * Definition for singly-linked list with a random pointer. 3 * class RandomListNode { 4 * int label; 5 * RandomListNode next, random; 6 * RandomListNode(int x) { this.label = x; } 7 * }; 8 */ 9 public class Solution {10 public RandomListNode copyRandomList(RandomListNode head) {11 Map<RandomListNode,RandomListNode> map = new HashMap<RandomListNode,RandomListNode>();12 if (head==null) return null;13 14 RandomListNode head2 = new RandomListNode(head.label);15 map.put(head,head2);16 RandomListNode cur = head2;17 18 while (head!=null){19 RandomListNode rand1 = head.random;20 if (rand1!=null && map.containsKey(rand1)){21 cur.random = map.get(rand1);22 } else if (rand1!=null) {23 RandomListNode rand2 = new RandomListNode(rand1.label);24 map.put(rand1,rand2);25 cur.random = rand2;26 }27 28 if (head.next==null){29 cur.next=null;30 } else {31 RandomListNode next = head.next;32 if (map.containsKey(next))33 cur.next = map.get(next);34 else {35 RandomListNode next2 = new RandomListNode(next.label);36 cur.next = next2;37 map.put(next,next2);38 }39 }40 41 head = head.next;42 cur = cur.next;43 }44 45 return head2; 46 }47 }
Leetcode-Copy List with Random Pointer
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。