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;
    }
    }


    }


  • 相关阅读:
    树状数组基本操作
    P1802 5倍经验日 题解
    函数学习总结
    康托展开
    中国电信CDMA无线上网卡短信收发
    报错:无法获取实体类XXX对应的表名!
    javajvisualvm远程监控云服务器上的Tomcat8.5
    服务器防火墙开放端口
    报错:列"AGENT_ENTITY_NAME"的值太大(实际值: 60,最大值50) oracle VARCHAR2和NVARCHAR2的区别
    linux中查看端口是否被占用lsof i:port
  • 原文地址:https://www.cnblogs.com/Transkai/p/10969730.html
Copyright © 2011-2022 走看看