链表面试题--复制复杂链表(java)

复制复杂链表
复杂链表
每个结点中有结点值,以及两个指针,一个 next 指针,指向下一个结点;一个 random 指针(特殊指针)指向任意结点。
思路

  1. 遍历原链表,复制每个结点,把新结点插入对应老结点后边
  2. 遍历每组(老+新)结点,进行random 的复制
      cur.next.random = cur.random.next
  3. 拆分成新老链表
    在这里插入图片描述
    主要代码
public static Node copyRandomList(Node head){
  if(head==null){
   return null;
  }
  //复制每个结点,插入老结点后边
  Node cur=head;
  while(cur!=null){
   //复制的新结点
   Node node=new Node(cur.val);
   node.next=cur.next;
   cur.next=node;
   //cur指向老的下一个结点
   cur=node.next;
  }
  //2.random复制
  cur=head;
  while(cur!=null){
   if(cur.random!=null){
    cur.next.random=cur.random.next;
   }else{
    cur.next.random=null;
   }
   //cur指向老的下一个结点
   cur=cur.next.next;
   
  }
  //3.把head拆分新的老的链表
  cur=head;
  Node newHead=head.next;
  while(cur!=null){
   
   Node node=cur.next;
   cur.next=node.next;
   if(node.next!=null){
    node.next=node.next.next;
   }
   //cur指向老的下一个结点
   cur=cur.next;
  }
  return newHead;
 }

完整代码

class Node{
 int val;
 Node next;
 Node random;
 Node(int x){
  val=x;
 }
}
public class Interview{
 public static void display(Node head){
  for(Node cur=head;cur!=null;cur=cur.next){
   System.out.printf("(%d)-->",cur.val);
  }
  System.out.println("null");
 }
 public static Node createLinkedList(){
  Node n1=new Node(1);
  Node n2=new Node(2);
  Node n3=new Node(3);
  Node n4=new Node(4);
  Node n5=new Node(5);
  n1.next=n2;
  n2.next=n3;
  n3.next=n4;
  n4.next=n5;
  n5.next=null;
  n1.random=n2;
  
  return n1;
 }
 public static Node copyRandomList(Node head){
  if(head==null){
   return null;
  }
  //复制每个结点,插入老结点后边
  Node cur=head;
  while(cur!=null){
   //复制的新结点
   Node node=new Node(cur.val);
   node.next=cur.next;
   cur.next=node;
   //cur指向老的下一个结点
   cur=node.next;
  }
  //2.random复制
  cur=head;
  while(cur!=null){
   if(cur.random!=null){
    cur.next.random=cur.random.next;
   }else{
    cur.next.random=null;
   }
   //cur指向老的下一个结点
   cur=cur.next.next;
   
  }
  //3.把head拆分新的老的链表
  cur=head;
  Node newHead=head.next;
  while(cur!=null){
   
   Node node=cur.next;
   cur.next=node.next;
   if(node.next!=null){
    node.next=node.next.next;
   }
   //cur指向老的下一个结点
   cur=cur.next;
  }
  return newHead;
 }
 public static void main(String[] args){
  Node head=createLinkedList();
  display(head);
  Node result=copyRandomList(head);
  display(result);
  
 }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值