当前位置: 首页 > article >正文

复制带随机指针的复杂链表

目录

  • 一、题目+题目链接
  • 二、题目分析
  • 三、解题思路
  • 四、解题步骤
    • 4.1 复制结点并链接到对应原节点的后面
    • 4.2 处理复制的结点的随机指针random
    • 4.3 分离复制的链表结点和原链表结点并重新链接成为链表
  • 五、参考代码
  • 六、总结

一、题目+题目链接

​​​​在这里插入图片描述

题目链接:https://leetcode.cn/problems/copy-list-with-random-pointer/

二、题目分析

这道题是要求我们复制给定的链表,给定的链表带有一个随机的指针random,该指针random的指向是不确定的方向的,并且不能破坏原来的链表结构。

三、解题思路

这道题的思路可以分成三步:

1、逐一复制原链表的结点,并在复制的同时把复制的结点链接在被复制结点的后面。


2、处理random的指向,由于每个复制的结点都在被复制结点的后面,所以复制结点的random就在被复制结点random的后一个。(最重要的一步)


3、分离复制的结点和被复制的结点并依次链接。

四、解题步骤

4.1 复制结点并链接到对应原节点的后面

定义三个指针cur,copy和next,按照以下方式复制结点并链接起来。当cur为NULL的时候就结束。

在这里插入图片描述
复制结束后的效果如下:

在这里插入图片描述

4.2 处理复制的结点的随机指针random

在这里插入图片描述
在这里插入图片描述
最核心的步骤是copy->random=cur->random->next,原因参考上面动图。

处理完之后的效果图如下:
在这里插入图片描述

cur为空就证明已经处理完了。

4.3 分离复制的链表结点和原链表结点并重新链接成为链表

在这里插入图片描述
在这里插入图片描述

分离后的效果图如下:
在这里插入图片描述

最后返回copyHead指针即可!!!

五、参考代码

typedef struct Node Node;
struct Node* copyRandomList(struct Node* head)
{
    if(head==NULL)
    {
        return NULL;
    }
    //1.复制链表
    Node* cur=head;
    while(cur)
    {
        Node* copy=(Node*)malloc(sizeof(Node));
        copy->val=cur->val;

        Node* next=cur->next;
        cur->next=copy;
        copy->next=next;
        cur=next;
    }

    //2.处理random
    cur=head;
    while(cur)
    {
        Node* copy=cur->next;
        if(cur->random)
        {
            copy->random=cur->random->next;
        }
        else
        {
            copy->random=NULL;
        }

        cur=copy->next;
    }

    //3.拆
    cur=head;
    Node* copyHead=cur->next;
    while(cur)
    {
        Node* copy=cur->next;
        Node* next=copy->next;
        cur->next=next;
        if(next)
        {
            copy->next=next->next;
        }
        cur=next;
    }

    return copyHead;


}

六、总结

如果你觉得你链表这块的知识已经学得很扎实了,那这道题就是对你链表知识的考验,链表的大部分知识都包含在了这道题上面,如果能够理清这一题的思路并且做出来,那链表这一块的知识基本上就是ok的了,这道题还是由一定的难度的,而且细节很多,你学会了吗??喜欢的话点点赞点点关注哟!!!


http://www.kler.cn/a/1719.html

相关文章:

  • 【0379】Postgres内核 walreceiver (libpqwalreceiver API)分析
  • c++表达范围勿用数学符号
  • OpenMV与STM32通信全面指南
  • 【从零开始入门unity游戏开发之——C#篇43】C#补充知识——值类型和引用类型汇总补充、变量的生命周期与性能优化、值类型和引用类型组合使用
  • csrf跨站请求伪造(portswigger)无防御措施
  • Three.js教程004:坐标辅助器与轨道控制器
  • 【二】一起算法---队列:STL queue、手写循环队列、双端队列和单调队列、优先队列
  • 【微信小程序】-- 分包 - 独立分包 分包预下载(四十五)
  • MySQL高级功能:存储过程、触发器、事务、备份和恢复
  • windows安装包管理工具Chocolatey
  • Java 到底是值传递还是引用传递?
  • java基础面试题(一)
  • Windows安装部署nginx
  • 【JavaEE】进程和线程
  • 自动驾驶TPM技术杂谈 ———— 超声波雷达系统测距
  • C++修炼之筑基期第一层——认识类与对象
  • 函数指针->回调函数
  • 大环境不好,找工作太难?三面阿里,幸好做足了准备,已拿offer
  • 【Java web】-转发和重定向
  • C++单继承和多继承
  • 智能生活垃圾检测与分类系统(UI界面+YOLOv5+训练数据集)
  • Kubernetes学习(七)补充:基于自定义指标进行扩缩容
  • 浅析“面向对象编程思想”
  • 【C语言】字符串函数和内存函数
  • 【Spring】我抄袭了Spring,手写一套MySpring框架。。。
  • 来到CSDN的一些感想