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

网站搜索排名优化价格收集链接 做网站

网站搜索排名优化价格,收集链接 做网站,知名自助建站平台,企业文化经典句子复制带随机指针的链表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/293208/

相关文章:

  • 百元建站餐饮网站开发参考文献
  • 上海网站建设找摩彼乐清网站建设哪家好
  • 类似红盟的网站怎么做dw2018网页制作步骤图文
  • 建设网站赚钱吗青岛app开发公司排行榜
  • 获取网站浏览者手机号外贸定制网站建设电话
  • 购物网站开发价格吉林市网站制作哪家好
  • 石家庄网站建设价格论述电子商务网站的建设
  • 乌兰县wap网站建设公司岳阳seo官网
  • 网站建设公司哪家好 要上磐石网络科讯怎么建设网站
  • 做点击率的网站企业网站开发一薇
  • 网站建设与管理维护自己搭服务器 做购物网站成本
  • 网站上漂亮的甘特图是怎么做的wordpress小工具点
  • 服务专业的网页制作服务2019做seo网站
  • 网站建设项目的实训报告wordpress 500一片空白
  • 网站友情链接要加什么用最新舆情信息网
  • 网站加入百度广告联盟牡丹江关键词优化
  • 九江专业网站建设定制如何注册商标名称以及logo
  • 上海网站seo优化网站建设费用的财务核算
  • 网站建设网做app软件大概多少钱
  • 平邑做网站的手机开发工具有哪些
  • 俄罗斯门户网站传新闻到网站上怎么做
  • 申请免费网站注册erp软件是什么软件
  • 学网站建设需要什么软件广州手机网站设计
  • 邯郸网站设计多少钱中煤矿山建设集团网站
  • 宜昌哪里有专业做网站的会做网站开发 但是不会二次开发
  • 微小店网站建设多少钱站长之家工具
  • 网站建设与实践高自考松江移动网站建设
  • 做网站的账务处理蓝鸟E4A做网站程序
  • 大连公司网站开发成都优化网站分析
  • 网站建设公司顺义软件大全链接网站