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

wix做的网站 网址是什么网页制作与网站建设技术大全 pdf

wix做的网站 网址是什么,网页制作与网站建设技术大全 pdf,建设网站交流,便民网app下载题目 如果一个链表中包含环,那么应该如何找出环的入口节点?从链表的头节点开始顺着next指针方向进入环的第1个节点为环的入口节点。 例如,在如图4.3所示的链表中,环的入口节点是节点3。 分析 第1步:确认是否包含环…

题目

如果一个链表中包含环,那么应该如何找出环的入口节点?从链表的头节点开始顺着next指针方向进入环的第1个节点为环的入口节点。

例如,在如图4.3所示的链表中,环的入口节点是节点3。
在这里插入图片描述

分析

第1步:确认是否包含环

定义两个指针并同时从链表的头节点出发,一个指针一次走一步,另一个指针一次走两步。如果链表中不包含环,走得快的指针直到抵达链表的尾节点都不会和走得慢的指针相遇。如果链表中包含环,走得快的指针在环里绕了一圈之后将会追上走得慢的指针。因此,可以根据一快一慢两个指针是否能够相遇来判断链表中是否包含环。

第2步:如何找到环的入口节点

定义两个指针来解决。先定义两个指针P1和P2,指向链表的头节点。如果链表中的环有n个节点,第1个指针P1先在链表中向前移动n步,然后两个指针以相同的速度向前移动。当第2个指针P2指向环的入口节点时,指针P1已经围绕环走了一圈又回到了入口节点。
在这里插入图片描述

第3步:如何得到环中节点的数目

前面在判断链表中是否有环时用到了一快一慢两个指针。如果两个指针相遇,则表明链表中存在环。两个指针之所以会相遇是因为快的指针绕环一圈追上慢的指针,因此它们相遇的节点一定是在环中。可以从这个相遇的节点出发一边继续向前移动一边计数,当再次回到这个节点时就可以得到环中节点的数目。

public class Test {public static void main(String[] args) {ListNode listNode1 = new ListNode(1);ListNode listNode2 = new ListNode(2);ListNode listNode3 = new ListNode(3);ListNode listNode4 = new ListNode(4);ListNode listNode5 = new ListNode(5);ListNode listNode6 = new ListNode(6);listNode1.next = listNode2;listNode2.next = listNode3;listNode3.next = listNode4;listNode4.next = listNode5;listNode5.next = listNode6;listNode6.next = listNode3;ListNode result = detectCycle(listNode1);System.out.println(result.val);}public static ListNode detectCycle(ListNode head) {ListNode inLoop = getNodeInLoop(head);if (inLoop == null) {return null;}int loopCount = 1;for (ListNode n = inLoop; n.next != inLoop; n = n.next) {loopCount++;}ListNode fast = head;for (int i = 0; i < loopCount; i++) {fast = fast.next;}ListNode slow = head;while (slow != fast) {fast = fast.next;slow = slow.next;}return slow;}// 快慢指针找到相遇的节点private static ListNode getNodeInLoop(ListNode head) {if (head == null || head.next == null) {return null;}ListNode slow = head.next;ListNode fast = slow.next;while (slow != null && fast != null) {if (slow == fast)return slow;slow = slow.next;fast = fast.next;if (fast != null)fast = fast.next;}return null;}
}
http://www.yayakq.cn/news/752911/

相关文章:

  • 上海网站制作服务我要外包网站
  • wap音乐网站源码学做网站用谁的书
  • 娱乐手机网站开发沈阳企业网站开发
  • 美容加盟的网站建设wordpress小论坛小程序
  • 网站连接数据库失败wordpress安装不上
  • 如何建立自己的论坛南京做网站优化价格
  • 公司网站彩页怎么做公路水运建设质量与安全监督系统网站
  • 哪个公司做公司网站好加强网站建设的建议
  • 安徽建新建设工程有限公司网站网络优化的内容有哪些
  • 做自媒体网站陵水网站建设费用
  • 赣州律师网站建设重庆互联网
  • 西数网站助手旧房改造找哪家
  • 网站一定要备案吗青海省高等级公路建设管局网站
  • 贵阳建站模板wordpress 链接跳转
  • 计算机应用技术php网站开发哪个网站的pc端是用vue做的
  • windows 网站开发上海公关公司排名
  • 阿克苏市建设局网站wordpress评论数据库分离
  • 淘宝客网站需要备案鼓楼机关建设网站
  • 模仿网站建设网站维护工作方案
  • 京东淘宝网站是怎么做的韩国网站 后缀
  • 做摄影和后期的兼职网站德兴市网站建设服务公司
  • 学校网站建设先进事迹一般做海报的图片跟哪个网站下载
  • 门图书馆户网站建设方案jsp网站开发教学视频
  • 网站建设规划书参考模板网站域名ip地址查询
  • 网站怎么做浏览量才会多wordpress图片网站
  • 石家庄的网站建设公司哪家好有做浏览单的网站
  • 做优化网站注意什么小企业网站建设方案
  • 修改网站dns公司网站搭建流程
  • 张掖市作风建设年活动网站设计上海兼职网站建设
  • 站内seo是什么意思西安网站建设麦欧科技