offer_JZ25
offer_JZ25
题目:
输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针random指向一个随机节点),请对此链表进行深拷贝,并返回拷贝后的头结点。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)
思路:
具体做法可以分为四步
第一:输入一个复杂链表,返回结果为复制后复杂链表的head
第二:根据原始链表的每个结点N创建对应的结点N'
第三:设置复制出来结点的random.假设原始结点的随机指向S,复制出来结点的random指向S后一个
第四:把这个长链表拆分成两个链表,奇数位置连接起来就是原始链表,偶数结点连接起来就是复制结点
public RandomListNode Clone(RandomListNode pHead) {
CloneNodes(pHead);//根据所给的头结点进行拷贝
ConnectRandomNodes(pHead);//设置随机值
return ReConnectNodes(pHead);//返回分好的偶数结点
}
// 第一步:根据原始链表的每个结点N创建对应的结点N'
private void CloneNodes(RandomListNode pHead) {
RandomListNode node = pHead;//定义一个结点,指向头原来的头结点
while (node != null) {//只要 原来的 当前结点 不空
RandomListNode cloneNode = new RandomListNode(node.label);//new一个新的结点,并且结点的值域与原来的结点相同
cloneNode.next = node.next;//将新的结点的next指向原来的当前结点的下一个结点
cloneNode.random = null;//random先不管,置空
node.next = cloneNode;//把原来当前结点的next指向新的结点
node = cloneNode.next;//把原来的当前结点往后移一个位置,也就是把新的结点的next指向赋值给node
}
}
// 第二步:设置复制出来结点的random.假设原始结点的随机指向S,复制出来结点的random指向S后一个
private void ConnectRandomNodes(RandomListNode pHead) {
RandomListNode node = pHead;
while (node != null) {
RandomListNode clone = node.next;//偶数位置就是克隆出来的新的结点,也是原来结点的next的指向
if (node.random != null) {//如果原来的结点的random不是空
clone.random = node.random.next;//把原来random里面的东西赋值给克隆结点的random;
}
node = clone.next;//原来的当前位置往后移
}
}
// 第三步:把这个长链表拆分成两个链表,奇数位置连接起来就是原始链表,偶数结点连接起来就是复制结点
private RandomListNode ReConnectNodes(RandomListNode pHead) {
RandomListNode node = pHead;//当前结点指向原来的头结点
RandomListNode cloneHead = null;//复制的头结点指向空
RandomListNode cloneNode = null;//当前的复制结点指向空
// 设置第一个节点
if (node != null) {
cloneHead = node.next;//偶数位置就是克隆出来的新的结点,也是原来结点的next的指向,用克隆的头结点指向这个克隆的结点,标记原来结点的下一个结点是克隆结点的头结点
cloneNode = node.next;//把当前的克隆结点指向原来的当前结点的下一个结点
node.next = cloneNode.next;//把原来的当前结点的next的指向换成克隆结点指向的结点
node = node.next;//后移
}
while (node != null) {
cloneNode.next = node.next;//把当前克隆结点的next指向换成原来的当前结点的下一个结点
cloneNode = cloneNode.next;//当前的克隆结点的位置后移一个结点
node.next = cloneNode.next;//把原来的当前结点的next指向换成当前克隆结点的下一个结点
node = node.next;//原来的当前结点后移一个结点
}
return cloneHead;
}
图示:第三步中的
设置第一个结点
// 设置第一个节点
if (node != null) {
cloneHead = node.next;//偶数位置就是克隆出来的新的结点,也是原来结点的next的指向,用克隆的头结点指向这个克隆的结点,标记原来结点的下一个结点是克隆结点的头结点
cloneNode = node.next;//把当前的克隆结点指向原来的当前结点的下一个结点
node.next = cloneNode.next;//把原来的当前结点的next的指向换成克隆结点指向的结点
node = node.next;//后移
}
- 继续
// 设置第一个节点
if (node != null) {
cloneHead = node.next;//偶数位置就是克隆出来的新的结点,也是原来结点的next的指向,用克隆的头结点指向这个克隆的结点,标记原来结点的下一个结点是克隆结点的头结点
cloneNode = node.next;//把当前的克隆结点指向原来的当前结点的下一个结点
node.next = cloneNode.next;//把原来的当前结点的next的指向换成克隆结点指向的结点
node = node.next;//后移
}
while (node != null) {
cloneNode.next = node.next;//把当前克隆结点的next指向换成原来的当前结点的下一个结点
cloneNode = cloneNode.next;//当前的克隆结点的位置后移一个结点
node.next = cloneNode.next;//把原来的当前结点的next指向换成当前克隆结点的下一个结点
node = node.next;//原来的当前结点后移一个结点
}
总结
xxx.next
在等号的左边 代表 xxx的next这个尾巴的指向
在等号的右边 代表 xxx的next的下一个结点实体
offer_JZ25的更多相关文章
随机推荐
- 如何成为一位优秀的ScrumMaster
嗨,大家好,我是叶子 背景介绍 目标:为了能更好的适应快速变化的需求和不确定的未来. 部门包含岗位:部门负责人.项目经理.产品经理.开发团队(开发人员.测试人员) 那么这种情况下,我们想转型Scrum ...
- hystrix文档翻译之运维
hystrix不仅用作工程可靠性还可以用来运维. 这里将会分享一个拥有100+Hystrix命令,40+线程池,每天有100亿次线程请求,2000亿次信号量请求的系统是如何使用hystrix运维的.这 ...
- Java中toCharArray()方法
Java中 toCharArray() 方法详解 <Thinking in Java>Chapter11中存在下列代码 package holding; import java.util. ...
- Oracle学习(十二)标量函数
UCASE()大写转换 LCASE()小写转换 --把查询结果对应的列进行大写转换 SELECT UCASE(列) FROM 表; --把查询结果对应的列进行小写转换 SELECT LCASE(列) ...
- 二分类问题续 - 【老鱼学tensorflow2】
前面我们针对电影评论编写了二分类问题的解决方案. 这里对前面的这个方案进行一些改进. 分批训练 model.fit(x_train, y_train, epochs=20, batch_size=51 ...
- Processing 网格(棋盘格)无限偏移纹理动画
过火 再度出击!这次我们要玩得更火一点---把静帧变动画.没错,将棋盘格动起来!看一下效果: 这是一个经典的无限偏移动画,在很多2d横版射击游戏中都会采用的技术.如何在Processing中实现,有两 ...
- 报表和仪表板在线设计器Stimulsoft Designer 最新版发布
Stimulsoft Designer是统一的Stimulsoft框架的一部分,该框架包括用于生成报表和分析数据的引擎.报表设计器和查看器. 您可以在计算机上创建报表,继续使用在线设计器在云中对其进行 ...
- Python练习题 049:Project Euler 022:姓名分值
本题来自 Project Euler 第22题:https://projecteuler.net/problem=22 ''' Project Euler: Problem 22: Names sco ...
- 给子元素设置margin-top无效果的一种解决方法
在写一个登陆界面的时候,设置登录按钮的margin-top时出了问题 先是这么写的 <div style="margin-top:30px"> <a style= ...
- Layman PHP+JavaScript 实现图片无刷新上传
html文件代码 <!-- ajax文件上传开始 --> <script type="text/javascript" src="/imageuploa ...