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

技术支持:洛阳网站建设企业自助建站哪家好

技术支持:洛阳网站建设,企业自助建站哪家好,wordpress响应速度忽快忽慢,网站程序和数据库复制带随机指针的链表1.题目2.解题思路3.完整代码1.题目 题目链接: https://leetcode.cn/problems/copy-list-with-random-pointer/ 给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。 …

复制带随机指针的链表

        • 1.题目
        • 2.解题思路
        • 3.完整代码

1.题目

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

给你一个长度为 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 作为传入参数。

2.解题思路

我们分3个步骤来解决这个题目:

1.复制结点,插入到原结点和下一个结点之间;

2.根据原结点的random,处理复制结点的random;

3.把拷贝的结点解下来存放到新的链表中,恢复原链表的链接关系。

步骤一画图理解:
开辟一个copy的结点,把cur->val的值赋给copy->val,接着把copy->next指向cur->next,又把cur->next=copy,最后让cur=copy->next;此做动作一直循环,直到cur等于NULL时结束。
在这里插入图片描述
步骤二:
让copy指向cur的下一个结点,如果cur->randomNULL,则copy->randomNULL,否则copy->random=cur->random->next ,最后cur=copy->next;此动作一直循环,直到cur==NULL时结束。
在这里插入图片描述
第一个原结点的random指向的是NULL,所以拷贝结点的random也是指向的NULL;
第二个原结点的random指向的是7,所以拷贝结点的random也是指向的7,这里的7是拷贝结点的7;
这里copy->random=cur->random->next不太好理解,就是拷贝结点的random是指向原结点的random的next,这样才能指向7这个拷贝的结点。

步骤三:
首先定义两个指针,copyHead和copyTail指针初始化为NULL,用来存放拷贝的结点,组成一个新链表,再定义一个cur指向head,copy指向cur的下一个结点,next指向copy的下一个结点;
解结点:把copy结点放到新链表中,如果copyTail/copyHead为空,则把copy的结点放到里面去,否则把copy结点放到copyTail中去,然后让copyTail指向copy,最后让cur->next指向next,cur指向next(为下一次循环做准备)。

在这里插入图片描述
把拷贝的结点解下来的同时需要把原链表的链接关系重新链接好。

这样就算是把原链表深拷贝了。

3.完整代码

struct Node* copyRandomList(struct Node* head) {//复制结点,插入到原结点和下一个结点之间struct Node* cur =head;while(cur){struct Node* copy = (struct Node*)malloc(sizeof(struct Node));copy->val = cur->val;copy->next = cur->next;cur->next = copy;cur = copy->next;}//根据原结点的random,处理复制结点的randomcur = head;while(cur) {struct Node* copy = cur->next;if(cur->random == NULL){copy->random = NULL;}else{copy->random = cur->random->next;}cur = copy->next;}//把拷贝的结点解下来存放到新的链表中,恢复原链表的链接关系struct Node* copyHead = NULL, *copyTail = NULL;cur = head;while(cur){struct Node* copy = cur->next;struct Node* next = copy->next;if(copyTail == NULL){copyHead = copyTail = copy;}else{copyTail->next = copy;copyTail = copy;}//为下一次循环做准备cur->next = next;cur = next;}return copyHead;
}

不管你认为这篇文章写的好不好,反正没人点赞👍

http://www.yayakq.cn/news/756602/

相关文章:

  • 长春h5建站模板在招聘网站做销售
  • 做业务在那几个网站上找客户端网站可分为哪两种类型
  • 团智慧登录入口网站推广优化服务
  • 网站在线布局百度网站改版
  • 怎样制作网站电话河南省干部任免最新公示
  • vs做网站如何调试两个公司的网站建设
  • 本地网站建设流程西宁解封最新通知
  • php开源企业网站台州cms模板建站
  • 南昌哪里做网站比较好长沙房地产信息网官网
  • 无锡市新区建设环保局网站优惠券网站开发哪家好
  • 网站建设细化流程wordpress 分类 分页
  • 怎么用自己的电脑做网站主机vr功能网站建设
  • 赣榆网站制作全国工程信息查询平台
  • 游戏行业seo整站优化怎么查看网站死链
  • 那曲网站建设网站风格细节
  • 专业的营销型网站建设价格数据中台搭建
  • 行业门户网站建设方案书设计工作室简介怎么写
  • 网站建设 话术网站建设方案汇报
  • 眉山网站优化网站规划说明书范文
  • 网站做接口如何免费做网站
  • 百度智能云网站建设主做销售招聘的招聘网站有哪些
  • 丹东网站建设网络维护工作总结
  • 济南外贸网站建设公司排名网站数据模版
  • 做儿童方面的网站电子商务是干什么工作的
  • 在大学做网站网站主页效果图
  • 怎么自己编写网站潍坊网站建设方案书
  • 如何做动漫网站长春网站建设网站制作推广
  • 网站设计论文答辩问题及答案旅游网站html
  • 网站制作方案阿里域名注册查询
  • 织梦淘宝客网站黑龙江省关于城市建设政策网站