码迷,mamicode.com
首页 > 其他好文 > 详细

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.

时间:2016-05-19 10:40:03      阅读:256      评论:0      收藏:0      [点我收藏+]

标签:

图解:技术分享

此题过程分为三个阶段,分别是 1、负责后面一个节点,并且将这个节点插入到原来链表中  2、复制后面一个节点的random指针。 3 拆分组合链表为两部分。

第一部分代码:

  while(currentnode!=null){//复制节点,并且将节点插入到该节点的后面
              RandomListNode clonenode=new RandomListNode(currentnode.label);
              clonenode.next=currentnode.next;
              currentnode.next=clonenode;
              currentnode=clonenode.next;
          }

第二部分 代码:

  currentnode=head;
          while(currentnode!=null){//复制随机指针。
              RandomListNode  clonenode=currentnode.next;
              if(currentnode.random!=null){
                  clonenode.random=currentnode.random.next;//这里要指向随机指针的后一个,因为是复制滴啊,千万不要忘记了。
              }
              currentnode=clonenode.next;
          }

第三部分代码:

  RandomListNode cloneHead=head.next;
          currentnode=head;
          while(currentnode.next!=null){
              RandomListNode temp=currentnode.next;
              currentnode.next=temp.next;
              currentnode=temp;
          }

总的代码:

class RandomListNode {
     int label;
     RandomListNode next, random;
     RandomListNode(int x) { this.label = x; }
 };
public class Solution {
      public RandomListNode copyRandomList(RandomListNode head) {
          if(head==null)return null;
          RandomListNode currentnode=head;
          while(currentnode!=null){//复制节点,并且将节点插入到该节点的后面
              RandomListNode clonenode=new RandomListNode(currentnode.label);
              clonenode.next=currentnode.next;
              currentnode.next=clonenode;
              currentnode=clonenode.next;
          }
          currentnode=head;
          while(currentnode!=null){//复制随机指针。
              RandomListNode  clonenode=currentnode.next;
              if(currentnode.random!=null){
                  clonenode.random=currentnode.random.next;//这里要指向随机指针的后一个,因为是复制滴啊,千万不要忘记了。
              }
              currentnode=clonenode.next;
          }
          
          RandomListNode cloneHead=head.next;
          currentnode=head;
          while(currentnode.next!=null){
              RandomListNode temp=currentnode.next;
              currentnode.next=temp.next;
              currentnode=temp;
          }
          return cloneHead;
            
      }
}

 

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.

标签:

原文地址:http://www.cnblogs.com/softwarewebdesign/p/5507543.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!