题目:请写一个函数clone(ComplexListNode pHead),实现复杂链表的复制。

复杂链表的数据结构如下:public class ComplexListNode{int m_nValue;ComplexListNode m_pNext;ComplexListNode m_pSliping//指向链表中的任何一个节点}

例如:m_pSliping指向NUll的,并没有画出来。

将复杂的问题简单化,各个击破:

思路:第一步,就是复制节点,并连接到原始节点的后面,第二步,设置复制出来节点的m_pSliping.第三步,将复制的链表从原始链表中分离。

如图:

Java代码:

public class ComplexLinkCloned {
//对于复杂链表的复制问题:1、复制节点,并连接到原始节点的后面。2.设置复制出来节点的m_pSliping。
//3.将复制的链表从原始的链表中分离出来。
public class ComplexListNode{
int m_nValue;
ComplexListNode m_pNext;
ComplexListNode m_pSliping;
}
//复制节点
public void clonedNode(ComplexListNode pHead){
if(pHead==null)
return;
ComplexListNode pNode=pHead;
while(pNode!=null){
ComplexListNode pClonedNode=new ComplexListNode();
pClonedNode.m_nValue=pNode.m_nValue;
pClonedNode.m_pNext=pNode.m_pNext;
pClonedNode.m_pSliping=null;
pNode.m_pNext=pClonedNode;
pNode=pClonedNode.m_pNext;
}
}
//设置m_pSliping
public void connectSlipingNode(ComplexListNode pHead){
if(pHead==null)
return;
ComplexListNode pNode=pHead;
while(pNode!=null){
ComplexListNode pCloned=pNode.m_pNext;
if(pNode.m_pSliping!=null){
pCloned.m_pSliping=pNode.m_pSliping.m_pNext;
}
pNode=pCloned.m_pNext;
} }
//将复制的链表从整个链表中分离
public ComplexListNode reConnectNode(ComplexListNode pHead){
ComplexListNode pNode=pHead;
ComplexListNode pClonedNode=null;
ComplexListNode pClonedHead=null;
if(pNode!=null){
pClonedHead=pClonedNode=pNode.m_pNext;
pNode.m_pNext=pClonedNode.m_pNext;
pNode=pNode.m_pNext;
}
while(pNode!=null){
pClonedNode.m_pNext=pNode.m_pNext;
pClonedNode=pClonedNode.m_pNext;
pNode.m_pNext=pClonedNode.m_pNext;
pNode=pNode.m_pNext; }
return pClonedHead;
}
public ComplexListNode Clone(ComplexListNode pHead){
clonedNode(pHead);
connectSlipingNode(pHead);
return reConnectNode(pHead);
} }

剑指offer-第四章解决面试题思路(复杂链表的复制)的更多相关文章

  1. 剑指offer第四章

    剑指offer第四章 1.二叉树的镜像 二叉树的镜像:输入一个二叉树,输出它的镜像 分析:求树的镜像过程其实就是在遍历树的同时,交换非叶结点的左右子结点. 求镜像的过程:先前序遍历这棵树的每个结点,如 ...

  2. 【剑指Offer面试编程题】题目1524:复杂链表的复制--九度OJ

    题目描述: 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点). 输入: 输入可能包含多个测试样例,输入以EOF结束. 对于每个测试案例,输入的第 ...

  3. 剑指offer-第四章解决面试题思路之总结

  4. 剑指offer-第四章解决面试题思路(字符串的排序)

    题目:输入一个字符串,打印出该字符串的全排列. 思路:将整个字符串分成两部分,第一部分为一个字符,将该字符和该字符后面的字符(直到最后一个字符)依次交换,确定第一个字符:然后固定第一个字符,将后面的字 ...

  5. 剑指offer-第四章解决面试题思路(二叉收索树和双向链表)

    题目:输入一个二叉收索树,将二叉搜索树转换成排序的双向链表.要求不能创建节点,只能将链表中的指针进行改变. 将复杂的问题简单化:思路:二叉收索树,本身是一个排序结构,中序遍历二叉收索树就可以得到一组排 ...

  6. 剑指offer-第四章解决面试题思路(判断一个数组是否为二叉搜索树的后序遍历序列)

    二叉搜索树:二叉搜索树根节点的左边都比根节点小,右边都比根节点大. 例题:输入一个数组,判断是否为二叉搜索树的后序遍历序列,如果是,返回true,如果不是,返回flase,假设没有重复的元素. 思路: ...

  7. 《剑指offer》第三十五题(复杂链表的复制)

    // 面试题35:复杂链表的复制 // 题目:请实现函数ComplexListNode* Clone(ComplexListNode* pHead),复 // 制一个复杂链表.在复杂链表中,每个结点除 ...

  8. 简直offer-第四章解决面试题思路(二叉树中和为某一值的路径)

    题目:输入一颗二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点往下一直到叶子节点形成一条路径. 思路:很明显用前序遍历可以从根节点开始遍历到叶子节点,然后将遍历的节点添加到 ...

  9. 剑指offer第五章

    剑指offer第五章 1.数组中出现次数超过一半的数 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组 ...

随机推荐

  1. BeatSaber节奏光剑插件开发官方教程2-简单的插件示例

    原文:https://wiki.assistant.moe/modding/example-mod 一.在开始之前 1 确保你已经看过教你如何添加插件模板的教程,且你已经使用插件模板创建了一个新项目 ...

  2. Autofac register and resolve

    Passing Parameters to Register When you register components you have the ability to provide a set of ...

  3. ubuntu 16.04 vscode + php debug

    1.vscode 安装PHP Debug扩展: 2.php环境配置: 1.安装xdebug扩展: sudo apt-get install php-xdebug 2.找到扩展的路径: chq@chq- ...

  4. struts2——文件下载自定义文件名,包括中文

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  5. 网络数据包头部在linux网络协议栈中的变化

    接收时使用skb_pull()不断去掉各层协议头部:发送时使用skb_push()不断添加各层协议头部. 先说说接收: * eth_type_trans - determine the packet' ...

  6. 比较好的SQL语句

    批次导数据表头 SELECT [运单号] , [运单号] AS [订单号] , [运单号] AS [订单号] , [运单号] , SUM([price] * [ProductNum]) AS [订单总 ...

  7. hibernate-Table 'XXX.XXX' doesn't exist

    hibernate---Table 'XXX.XXX' doesn't exist 在设置自动生成数据表的策略中: <!-- 自动生成数据表的策略 --> <property nam ...

  8. Java EE启示录

    前言 最近的这段时间一直在学习Java EE,刚刚完成了从0到1的蜕变,所以顺便整理一下我所了解到的Java EE,给刚入门学习的新人一些头绪,而所谓“启示录”,就是这个意思. 一.Java EE是什 ...

  9. sklearn中预测模型的score函数

    sklearn.linear_model.LinearRegression.score score(self, X, y, sample_weight=None) Returns the coeffi ...

  10. scala学习手记34 - trait方法的延迟绑定

    trait的方法的延迟绑定就是先混入的trait的方法会后调用.这一点从上一节的实例中也可以看出来. 下面再来看一个类似的例子: abstract class Writer { def write(m ...