复杂链表的复制

题目描述

输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)
假设原始链表为:下图中除去A'.B',C',D',E'的部分是原始链表,实线是正常指针,虚线是特殊指针指向特殊节点。经过第一个while循环后,变成下图

 

 

经过第二个while循环,变为:


使得A'指向C',D'指向B'
 
public RandomListNode Clone(RandomListNode head) {
if (Head == null)
return null;
RandomListNode cur = head;
//复制next 如原来是A->B->C 变成A->A'->B->B'->C->C'
while (cur != null) {
RandomListNode node = new RandomListNode(cur.label); //创建A
node.next = cur.next; //把B准备好,并赋给node.next
cur.next = node; //使得A->A'
cur = node.next; //把pCur移到B处
}
cur = head;
//复制random
while (cur != null) {
if (cur.random != null)
cur.next.random = cur.random.next;
cur = cur.next.next;
}

RandomListNode realHead = head.next; //head是A',B',C',D',E'链表的头
RandomListNode first = realHead;
RandomListNode last= head;

//拆分链表
while (first != null) {
last.next = last.next.next;
if (first.next != null)
first.next = first.next.next;
first = first.next;
last = last.next;
}
return realHead;
}
posted @   MarkLeeBYR  阅读(152)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示