当前位置: 首页 > 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.15wanjia.com/news/178282.html

相关文章:

  • 设计师搜图网站网站如何转做app
  • 哪里有做兼职的网站html个人网页代码模板
  • 网站建设设计图软件厦门海沧区建设局网站
  • a5站长平台开发jsp网站
  • 乐平网站设计珠海网站建设外包
  • 做金馆长网站网站数码产品网站模板
  • 互联网设计公司网站谷歌seo关键词优化
  • 青岛做优化网站哪家好宁波seo教程
  • vs做网站创建项目时选哪个网页设计尺寸多大
  • 纯静态做企业网站做个网站
  • 网站优化推广多少钱综合门户类网站有哪些
  • 金堂做网站的公司郯城网站建设
  • 中国建设招标网 官方网站下载青岛房产网链家
  • 5118网站查询做网站广告的点
  • 灰色网站怎么做seo地方门户模板
  • 台州自助建站公司wordpress 分类文章插件
  • 网站超链接怎么做 wordasp企业网站开发技术
  • 在网站挂广告一个月多少钱营销展示型网站建设价格
  • wps可以做网站吗建设工程公司起名
  • 在线做h5 的网站只做网站应该找谁
  • 网站建设岗位将来有什么发展北京云建站模板
  • 百度上怎么制作自己的网站站长之家排名查询
  • 个人网站备案 网站名称百度推广有哪些形式
  • 本地推广找哪些网站创网
  • 泉州建设人才网站百度下载安装2021最新版
  • 做网站主机要选好公关公司职位
  • 北京建设制作网站简述seo的概念
  • 给彩票网站做代理违法吗网页版微信怎么删除聊天记录
  • 河池网站建设网站开发会什么软件
  • 大创项目做英语网站wordpress 给标签加id