>Java >java지도 시간 >Java는 복잡한 연결 목록의 복사 코드 공유를 구현합니다.

Java는 복잡한 연결 목록의 복사 코드 공유를 구현합니다.

黄舟
黄舟원래의
2017-10-17 10:06:151480검색

이 기사에서는 Java 인터뷰 질문을 주로 소개합니다. 복잡한 연결 목록을 구현하기 위한 복사 코드를 공유하는 것이 꽤 좋고 참조할 가치가 있다고 생각합니다.

알리바바의 마지막 온라인 프로그래밍 질문, 적어서 모든 사람과 공유하세요

단방향 연결 목록이 있고, 각 노드에는 이 연결 목록의 노드를 가리키거나 비어 있는 임의의 포인터가 포함되어 있으며, 깊은 복사 기능을 작성합니다. , 임의 포인터를 포함하여 전체 연결 목록을 복사합니다. 가능할 때마다 가능한 예외를 고려하십시오.

알고리즘은 다음과 같습니다:


/*
public class RandomListNode {
  int label;
  RandomListNode next = null;
  RandomListNode random = null;
  RandomListNode(int label) {
    this.label = label;
  }
}
*/
public class Solution {
  public RandomListNode Clone(RandomListNode pHead)
  {
    copyNodes(pHead);
    setClonedNodes(pHead);
    return splitNodes(pHead);
  }
    //第一步,复制链表任意结点N并创建新结点N‘,再把N'链接到N的后面
   public static void copyNodes(RandomListNode head){ 
    RandomListNode temp = head;
    while(temp!=null){
     RandomListNode clonedNode = new RandomListNode(0);
     clonedNode.next = temp.next;
     clonedNode.label = temp.label;
     clonedNode.random = null;
     temp.next = clonedNode;
     temp = clonedNode.next;
    }
   }
   //第二步,设置复制出来的结点
   public static void setClonedNodes(RandomListNode head){
    RandomListNode pNode = head;
    while(pNode!=null){
     RandomListNode pCloned = pNode.next;
     if(pNode.random!=null){
      pCloned.random = pNode.random.next; 
     }
     pNode = pCloned.next;
    }
   }
   //第三步,将第二步得到的链表拆分成两个链表
   public static RandomListNode splitNodes(RandomListNode head){
    RandomListNode pNode = head;
    RandomListNode clonedHead = null;
    RandomListNode clonedNode = null;
    if(pNode!=null){
     clonedHead = pNode.next;
     clonedNode = pNode.next;
     pNode.next = clonedNode.next;
     pNode = pNode.next;
    }
    while(pNode!=null){
     clonedNode.next = pNode.next;
     clonedNode = clonedNode.next;
     pNode.next = clonedNode.next;
     pNode = pNode.next;
    }
    return clonedHead;
   }
}

요약

위 내용은 Java는 복잡한 연결 목록의 복사 코드 공유를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.