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

闵行网站建站多少钿网站建设需要注意的事情

闵行网站建站多少钿,网站建设需要注意的事情,四川炜航建筑公司网站,html在线编辑1.前言 前五题在这http://t.csdnimg.cn/UeggB 后三题在这http://t.csdnimg.cn/gbohQ 给定一个链表,判断链表中是否有环。http://t.csdnimg.cn/Rcdyc 给定一个链表,返回链表开始入环的第一个结点。 如果链表无环,则返回 NULLhttp://t.cs…

1.前言 

前五题在这http://t.csdnimg.cn/UeggB

后三题在这http://t.csdnimg.cn/gbohQ

给定一个链表,判断链表中是否有环。http://t.csdnimg.cn/Rcdyc 

给定一个链表,返回链表开始入环的第一个结点。 如果链表无环,则返回 NULLhttp://t.csdnimg.cn/pbFiK

记录每天的刷题,继续坚持!

2.OJ题目训练

11. 给定一个链表,每个结点包含一个额外增加的随机指针,该指针可以指向链表中的任何结点或空结点。 要求返回这个链表的深度拷贝。力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目分析

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

这道题第一次做还是会有点理解的...但其实也不复杂

其实就是,一个正常的单链表,但是有数据位,也能有指向下一个节点位,但是多出来一个指针会随机指向此链表的如何一个节点,而我们就要对他进行一个复制。复制单链表简单,但是我们要注意,这里还增加了一个额外的指针。而且我们复制的时候随机指针还是要指向原本对应的节点。

比如:下面的d1的随机指针指向了d3,而我们新的d1节点就要指向新的d3节点

若我们直接暴力复制原链表的所有值,就会发生这种错误情况

所以此题不能暴力求解。

方法

1.首先先把拷贝节点放在每个原节点后面,这样子就可以很好的查找各节点的random

2.置每个拷贝的节点random,因为我们可以依据相对位置找到原节点的random,再让他赋值

copy->random = cur->random->next       //拷贝random节点的关键代码

3.收尾工作:拷贝的节点和原节点分开,恢复原链表。

附源代码

/*** Definition for a Node.* struct Node {*     int val;*     struct Node *next;*     struct Node *random;* };*/struct Node* copyRandomList(struct Node* head) {struct Node* cur = head;while(cur){struct Node* copy = (struct Node*)malloc(sizeof(struct Node));struct Node* Next = cur->next;copy->val = cur->val;//插入copycur->next = copy;copy->next = Next;//往后走     cur = Next;}//重新开始走,因为random的特殊性//所以在copy节点没有全部创造出来还不能添加cur = head;while(cur){   struct Node* copy = cur->next;//置 copy randomif(cur->random == NULL) //考虑其中一种为0的情况,如果为NULL访问就会报错{copy->random = NULL;}else{copy->random = cur->random->next;} cur = copy->next;}//分割链表cur = head;struct Node* copyhead = NULL,*copytail = NULL;while(cur){struct Node* copy = cur->next;struct Node* next = cur->next->next;if(copytail == NULL){copyhead = copytail = copy;}else{copytail->next = copy;copytail = copytail->next;} cur->next = next;cur = next;}return copyhead;
}

12. 其他 。ps:链表的题当前因为难度及知识面等等原因还不适合我们当前学习,可以自行练习。

力扣

牛客网在线编程_算法篇_面试必刷TOP101

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

相关文章:

  • 企业宣传网站怎么建立自己的企业网站
  • 织梦m网站伪静态产品设计欣赏
  • 什么样的网站适合搜索引擎收录滨海新网站建设
  • 网站所有人郑州小程序
  • 浏览wap网站网站建设外包平台
  • 炫酷网站有哪些网站设计的基本过程
  • 建网站可以用企业qq吗忻州集团网站建设
  • 广州营销型网站建设费用三亚手机台app
  • 看案例网站wordpress做排名
  • 上海 高端 网站建设天空在线网站建设
  • 企业网站的域名是该企业的什么外贸网站seo有哪些公司
  • 徐州教育平台网站建设在线制作图片加字合成
  • 我有虚拟服务器怎么快速做网站稿定设计网站官网入口
  • 福田做网站的淘宝上开个网站建设
  • 企业网站开发的设计流程关于建设学校网站的报告书
  • 专业建站推广网络公司my23777免费域名查询
  • 绍兴cms建站系统寻找建设网站客户
  • 网站建设要不要监理网站悬浮
  • 国外有哪些网站是做弱电的安徽房和城乡建设部网站
  • 域名跟网站的区别吗诚信网站 互联网建站
  • 网站开发软件英文版推广任务平台
  • vps用什么软件做网站厦门网站建设屈兴东
  • 网站开发流程分为哪三个阶段网站栏目规划怎么写
  • 做外汇看新闻在什么网站看创新的常州做网站
  • 个人网站的设计wordpress去除文章rss
  • 菏泽市建设局网站电话wordpress侧边悬浮框
  • 诗词门户网站北京网站建站系统平台
  • 做围棋题最好的网站企业新闻稿发布平台
  • 成都 地铁 建设 网站建筑培训网址
  • 早晨设计 做网站设计吗网站建设单位不给数据库