算法大神对小码农说复制随机链表可以单独拿出来讲讲

简介: 算法大神对小码农说复制随机链表可以单独拿出来讲讲

文章目录


复制带随机指针的链表

天下傻逼独一个就是我,我忘记了选c语言,用c++结果错误看一脸懵逼

image.png

题目

image.pngimage.png

这题链表的复制难的地方就是随机指针random  如何复制他的指向,很多人的确想到了malloc节点,我也想到了malloc一个一个的节点,但是基本所有人都卡死在这里了,就是我们如何链,在这里我们就会又遇到先天性大佬的天赋思维力的压制,上一题是空间联想的压制。(来吧我小码农就喜欢给先天以及后天的大佬锤炼)

思想

普通拷贝

image.png

实际上想到这样也已经了不起了,有点磨具雏形了

顺藤摸瓜(这个是真的奇兵记,暗度陈仓的感觉)

image.png

脱裤子还需提裤子人(上面暗度陈仓,这个就是单刀直入)

image.png

代码实现

3.gif

4.gif

cur为NULL的时候就是停止copy的时候
  struct Node* cur = head;
    if(!cur)
        return NULL;
    while(cur)
    {
        //每次我们都要malloc一个copy节点
        struct Node* copy = (struct Node*)malloc(sizeof(struct Node));
        //开始给数据
        copy->val = cur->val;
        //开始插入
        copy->next = cur->next;
        cur->next = copy;
        //开始cur移动
        cur = copy->next;
    }


003.gif

有人说为什么不在上面malloc节点的时候就链,因为那时候小孩还没出生你就让你的还在上学吗,没错为了卷你们,我准备偷偷生个小孩
 //节点copy好后开始random相链
    cur = head;
    while(cur)
    {
        //重新把之前开辟的节点给copy维护
        struct Node* copy = cur->next;
        if(cur->random == NULL)
            copy->random = NULL;
        else
            copy->random = cur->random->next;//上面的GIF的核心代码       
        cur = copy->next;  
    }


5.gif

然后拿下来一个个尾插,就是单刀直入你要还原原来的链表顺序

 //开始一个一个尾插起来
    struct Node* copyHead = NULL;
    struct Node* copyTail = NULL;
    cur = head;
    while(cur)
    {
        //重新把之前开辟的节点给copy维护
        struct Node* copy = cur->next;
        //这边你需要一个next来还原原来链表顺序,你不能用完人家对人家不负责任
        struct Node* next = copy->next;
        if(copyHead == NULL)
        {
            copyHead = copy;
            copyTail = copy;
        }
        else
        {
            copyTail->next = copy;
            copyTail = copy;
        }        
        cur->next = next;//这一步看你对原来链表负不负责任
        cur = next;
    }
    return copyHead;

image.png

struct Node* copyRandomList(struct Node* head) {
  struct Node* cur = head;
    if(!cur)
        return NULL;
    while(cur)
    {
        //每次我们都要malloc一个copy节点
        struct Node* copy = (struct Node*)malloc(sizeof(struct Node));
        //开始给数据
        copy->val = cur->val;
        //开始插入
        copy->next = cur->next;
        cur->next = copy;
        //开始cur移动
        cur = copy->next;
    }
    //节点copy好后开始random相链
    cur = head;
    while(cur)
    {
        //重新把之前开辟的节点给copy维护
        struct Node* copy = cur->next;
        if(cur->random == NULL)
            copy->random = NULL;
        else
            copy->random = cur->random->next;//上面的GIF的核心代码       
        cur = copy->next;  
    }
    //开始一个一个尾插起来
    struct Node* copyHead = NULL;
    struct Node* copyTail = NULL;
    cur = head;
    while(cur)
    {
        //重新把之前开辟的节点给copy维护
        struct Node* copy = cur->next;
        //这边你需要一个next来还原原来链表顺序,你不能用完人家对人家不负责任
        struct Node* next = copy->next;
        if(copyHead == NULL)
        {
            copyHead = copy;
            copyTail = copy;
        }
        else
        {
            copyTail->next = copy;
            copyTail = copy;
        }        
        cur->next = next;//这一步看你对原来链表负不负责任
        cur = next;
    }
    return copyHead;
}


目录
相关文章
|
7天前
|
算法
【优选算法专栏】专题九:链表--------两两交换链表中的节点
【优选算法专栏】专题九:链表--------两两交换链表中的节点
16 0
|
1月前
|
算法
【数据结构与算法】题解 | #反转链表#
【数据结构与算法】题解 | #反转链表#
|
7天前
|
算法
算法系列--递归(一)--与链表有关(上)
算法系列--递归(一)--与链表有关
16 0
|
7天前
|
算法
算法系列--链表刷题(二)(下)
算法系列--链表刷题(二)(下)
13 0
|
1月前
|
算法 Java 索引
[Java·算法·简单] LeetCode 141. 环形链表 详细解读
[Java·算法·简单] LeetCode 141. 环形链表 详细解读
23 0
|
1月前
|
算法
常见算法题—707.设计链表
【2月更文挑战第10天】
34 7
|
1月前
|
存储 算法
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
|
1月前
|
存储 算法 C语言
【数据结构与算法】【约瑟夫问题】还在用递归?教你用链表秒杀约瑟夫
【数据结构与算法】【约瑟夫问题】还在用递归?教你用链表秒杀约瑟夫
|
1月前
|
机器学习/深度学习 算法 生物认证
基于深度学习的人员指纹身份识别算法matlab仿真
基于深度学习的人员指纹身份识别算法matlab仿真
|
26天前
|
传感器 算法 计算机视觉
基于肤色模型和中值滤波的手部检测算法FPGA实现,包括tb测试文件和MATLAB辅助验证
该内容是关于一个基于肤色模型和中值滤波的手部检测算法的描述,包括算法的运行效果图和所使用的软件版本(matlab2022a, vivado2019.2)。算法分为肤色分割和中值滤波两步,其中肤色模型在YCbCr色彩空间定义,中值滤波用于去除噪声。提供了一段核心程序代码,用于处理图像数据并在FPGA上实现。最终,检测结果输出到"hand.txt"文件。