zoukankan      html  css  js  c++  java
  • 剑指offer 25.分解让复杂问题简单 复杂链表的复制

    题目描述

    输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)

    解题思路


    package jianzhioffer.linkedlist;

    import com.sun.org.apache.xalan.internal.xsltc.dom.ClonedNodeListIterator;

    /**

    * @author hadoop
    */

    /*
    *解题思路:
    *1、遍历链表,复制每个结点,如复制结点A得到A1,将结点A1插到结点A后面;
    *2、重新遍历链表,复制老结点的随机指针给新结点,如A1.random = A.random.next;
    *3、拆分链表,将链表拆分为原链表和复制后的链表
    */
    public class Clone {

    public RandomListNode Clone(RandomListNode pHead) {
    if(pHead == null) {
    return null;
    }

    RandomListNode currentNode = pHead;
    //1、复制每个结点,如复制结点A得到A1,将结点A1插到结点A后面;
    while(currentNode != null){
    RandomListNode cloneNode = new RandomListNode(currentNode.label);
    RandomListNode nextNode = currentNode.next;
    currentNode.next = cloneNode;
    cloneNode.next = nextNode;
    currentNode = nextNode;
    }

    currentNode = pHead;
    //2、重新遍历链表,复制老结点的随机指针给新结点,如A1.random = A.random.next;
    while(currentNode != null) {
    currentNode.next.random = currentNode.random==null?null:currentNode.random.next;
    currentNode = currentNode.next.next;
    }

    //3、拆分链表,将链表拆分为原链表和复制后的链表
    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;
    }

    class RandomListNode {
    int label;
    RandomListNode next = null;
    RandomListNode random = null;

    RandomListNode(int label) {
    this.label = label;
    }
    }


    }


  • 相关阅读:
    Array 数组对象
    Math对象
    String 字符串对象
    Date 日期对象
    一个简单的计算器
    如何判断一个js对象是否一个DOM对象
    筛选if 运用
    移动端前端笔记大全
    一个元素的偏移的方法
    如果判断一个dom 对像?
  • 原文地址:https://www.cnblogs.com/Transkai/p/10969730.html
Copyright © 2011-2022 走看看