力扣HOT100之链表:138. 随机链表的复制

这道题要求将整个链表进行深拷贝,新链表中不包含任何原链表的节点,但是新链表中各个节点存储的值和各个节点的指向关系需要和原链表一模一样。我的思考过程如下:

1.新链表中的每一个节点的创建必须用new关键字来创建,而不能只是简单的拷贝赋值;

2.由于ramdom指针的随机性,A -> random可能指向nullptr,也可能指向A之后的某个节点,也有可能指向A之前的某个节点,也有可能指向自己,在构造链表的过程中,完全有可能出现A -> random对应的节点还没构造出来的情况,此外,按照random指针遍历链表可能出现有环的情况,从而导致无限循环。

3.要想遍历链表的所有节点,只能通过next指针进行遍历,因此在构造链表的过程中,我们应当使用next指针遍历整个链表,先将新链表的所有节点构造出来,然后再来逐个处理每一个节点的random指针的指向问题。
还有一个问题,就是原链表中的节点Arandom指针指向节点B,我们怎么将新链表中A'random指针指向B'?

我们可以使用一个整形变量offset来记录原链表中A -> random指针指向节点(B节点)相较于头节点的偏移量,然后我们在新链表中通过这个偏移量找到对应的节点,再将当前遍历到的节点的random指针指向偏移量为offset的节点。

下面结合一个简单的例子来说明一下解决的过程

代码如下

cpp 复制代码
/*
// Definition for a Node.
class Node {
public:
    int val;
    Node* next;
    Node* random;
    
    Node(int _val) {
        val = _val;
        next = NULL;
        random = NULL;
    }
};
*/

class Solution {
public:
    Node* copyRandomList(Node* head) {
        Node* new_head = head ? new Node(head -> val) : nullptr;   //新链表的头节点
        Node* current1 = head;
        Node* current2 = new_head;
        //先根据next指针将所有节点构造出来,并顺序连接
        while(current1){
            current2 -> val = current1 -> val;
            current2 -> next = current1 -> next ? new Node(current1 -> next -> val) : nullptr;
            current1 = current1 -> next;
            current2 = current2 -> next;
        }
        //按照顺序逐一构造random的指向
        current1 = head;
        current2 = new_head;
        while(current1){
            if(current1 -> random){   //random指向链表中的节点
                Node* temp_current1 = head;  //
                int offset = 0;   //计算偏移量
                while(temp_current1 != current1 -> random){
                    ++offset;
                    temp_current1 = temp_current1 -> next;
                }
                Node* temp_current2 = new_head;
                while(offset > 0){  //寻找新链表中当前节点的random指向的位置
                    temp_current2 = temp_current2 -> next;
                    --offset;
                }
                current2 -> random = temp_current2;    
            }
            current1 = current1 -> next;
            current2 = current2 -> next;
        }
        return new_head;
    }
};
相关推荐
诗9趁年华9 分钟前
深入分析线程池
java·jvm·算法
九年义务漏网鲨鱼1 小时前
【大模型面经】千问系列专题面经
人工智能·深度学习·算法·大模型·强化学习
源码之家2 小时前
机器学习:基于大数据二手房房价预测与分析系统 可视化 线性回归预测算法 Django框架 链家网站 二手房 计算机毕业设计✅
大数据·算法·机器学习·数据分析·spark·线性回归·推荐算法
Lv Jianwei2 小时前
Longest Palindromic Substring最长回文子串-学习动态规划Dynamic Programming(DP)
算法
WWZZ20252 小时前
快速上手大模型:深度学习7(实践:卷积层)
人工智能·深度学习·算法·机器人·大模型·卷积神经网络·具身智能
l1t2 小时前
用SQL求解advent of code 2024年23题
数据库·sql·算法
10岁的博客3 小时前
二维差分算法高效解靶场问题
java·服务器·算法
轻微的风格艾丝凡3 小时前
锂电池 SOC 估计技术综述:成熟算法、新颖突破与车企应用实践
算法·汽车
Codeking__3 小时前
动态规划算法经典问题——01背包问题
算法·动态规划
R-G-B3 小时前
归并排序 (BM20 数组中的逆序对)
数据结构·算法·排序算法