leetcode做题笔记138. 复制带随机指针的链表

给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。

构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的 next 指针和 random 指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点 。

例如,如果原链表中有 X 和 Y 两个节点,其中 X.random --> Y 。那么在复制链表中对应的两个节点 x 和 y ,同样有 x.random --> y 。

返回复制链表的头节点。

用一个由 n 个节点组成的链表来表示输入/输出中的链表。每个节点用一个 [val, random_index] 表示:

val:一个表示 Node.val 的整数。

random_index:随机指针指向的节点索引(范围从 0 到 n-1);如果不指向任何节点,则为 null 。

你的代码 只 接受原链表的头节点 head 作为传入参数。

思路一:回溯

c语言解法

cpp 复制代码
struct Node* copyRandomList(struct Node* head) {
        struct Node* cur=head;
        while(cur)
        {
            struct Node* next=cur->next;
            struct Node* copy=(struct Node*)malloc(sizeof(struct Node));
            copy->val=cur->val;

            cur->next=copy;
            copy->next=next;

            cur=next;
        }
        cur=head;
            while(cur)
        {
            struct Node* copy=cur->next;
            if(cur->random==NULL)
            {
                copy->random=NULL;
            }
            else
            {
                copy->random=cur->random->next;

            }
            cur=copy->next;
        }
        cur=head;
        struct Node* copyhead=NULL,*copytail=NULL;
        while(cur)
        {
            struct Node* copy=cur->next;
            struct Node* next=copy->next;

            if(copytail==NULL)
            {
                copytail=copyhead=copy;
            }
            else
            {
                copytail->next=copy;
                copytail=copytail->next;

            }
            cur->next=next;

            cur=next;
        }
        return copyhead;
        }

分析:

本题要对一个特殊的链表进行复制,这个链表每个节点包含一个额外增加的随机指针 random,可以先将该链表每个节点记录下来,当记录的节点的指针指向空节点时原复制的节点也指向空,最后将操作完的链表用copytail连接起来,最后输出copyhead

总结:

本题考察对链表的操作,要将链表深拷贝即将链表复制下来再根据具体情况添加最后连接后返回

相关推荐
wtmReiner15 分钟前
山东大学数值计算2026.1大三上期末考试回忆版
笔记·算法
黛色正浓16 分钟前
leetCode-热题100-滑动窗口合集(JavaScript)
javascript·算法·leetcode
jimmyleeee17 分钟前
人工智能基础知识笔记三十二:向量数据库的查找类型和工作原理
人工智能·笔记
漫随流水33 分钟前
leetcode算法(145.二叉树的后序遍历)
数据结构·算法·leetcode·二叉树
漫随流水1 小时前
leetcode算法(94.二叉树的中序遍历)
数据结构·算法·leetcode·二叉树
做cv的小昊1 小时前
【TJU】信息检索与分析课程笔记和练习(6)英文数据库检索—web of science
大数据·数据库·笔记·学习·全文检索
北岛寒沫2 小时前
北京大学国家发展研究院 经济学原理课程笔记(第二十五课 开放宏观基本概念)
经验分享·笔记·学习
北京理工大学软件工程2 小时前
代码随想录-C-笔记
笔记
小白探索世界欧耶!~2 小时前
用iframe实现单个系统页面在多个系统中复用
开发语言·前端·javascript·vue.js·经验分享·笔记·iframe
551只玄猫3 小时前
新编大学德语1第三版笔记 第3课Studentenleben
笔记·德语·外语·德语a1·德语笔记·自学德语·新编大学德语