当前位置:网站首页>虫子 环形链表
虫子 环形链表
2022-04-21 14:06:00 【华为云】
环链
环形链表
题目

分析


==我们剖析一下代码==

bool hasCycle(struct ListNode *head) { struct ListNode* fast = head,*slow = head; while(fast && fast->next) { fast = fast->next->next; slow = slow->next; if(fast == slow) return true; } return false;}
延伸问题:
==1.为什么fast和slow会在环中相遇,会不会有这么一种情况呢。就是在环中一直交错永远遇不上?请证明一下。==
结论:就上面fast和slow而言是一定相遇的
证明:
第一步:slow和fast,fast肯定是先进环,这时slow是fast入环前距离的一半。
第二步:随着slow进环,fast已经在环里走了一段了,走了 多少和环的大小有关系
第三步:我们这里假设slow进环的时候距离和fast是==N==
slow每次往前走1步,fast往前走两步,每追一次,判断一下相遇,结果为==N-1==,也就是说每追一次他们间的距离是一步一步的在减少,直到他们相遇

==这里就又衍生出了一个问题就是slow与fast只要是步差为一就可以相遇==
==2.为什么slow走一步,fast走两步呢?fast可不可以走大于两步呢?==
结论:fast走n步,n>2,不一定会相遇
这里分析一个slow走一步,fast走三步的交错与不交错的情况
他们之间的距离变化是每次是两两的减少,这也就意味着可能会交错

==上面的奇偶问题也就又衍生出了N是他们的步差倍数就能相遇==
环形链表 II
题目

==如何求环的入口点==
分析
我们先直接放结论==一个指针从相遇点开始走,一个指针从链表头开始走,他们会在环的入口点相遇==


struct ListNode *detectCycle(struct ListNode *head) { struct ListNode * fast = head,* slow = head; while(fast && fast->next) { fast = fast->next->next; slow = slow->next; if(slow == fast)//相遇 { //相遇节点 struct ListNode * meetNode = fast; while(meetNode != head) { meetNode = meetNode->next; head = head->next; } return meetNode; } } return NULL;}
版权声明
本文为[华为云]所创,转载请带上原文链接,感谢
https://bbs.huaweicloud.com/blogs/348949
边栏推荐
- C语言每日一题第一天
- Take you to play c language scanf and getchar easily
- 2021.10.24 程序员(媛)节日快乐!!!
- Notes on questions (I)
- 快速排序几种实现方法及其优化
- MySQL configures PXC high availability cluster
- 支付宝二面:如何用 UDP 实现可靠传输?
- ROS2学习笔记(五)-- ROS2命令行操作常用指令总结(一)
- Introduction to redis cluster construction and management
- uiautomator2 自动化测试工具使用
猜你喜欢
随机推荐
基于word2vec的k-means聚类
2021.10.24 程序员(媛)节日快乐!!!
【错误记录】Groovy工程中的文件查找策略 ( main 函数中需要使用 src/main/groovy/Script.groovy | Groovy 脚本直接使用代码相对路径 )
ROS2学习笔记(三)-- 采集虚拟仿真环境图像并发布
初学者3种简单排序的个人总结
如何关闭VS Code eslint校验,快来看看吧
Introduction to redis cluster construction and management
从源码里的一个注释,我追溯到了12年前,有点意思
Heap sorting -- Top-k problem solving and complexity analysis
C语言常量,字符串,转义字符,注释初阶
面了个腾讯拿 38K 出来的,让我见识到了基础的天花板
2500字,手把手带你初步了解static关键字和指针,结构体
恭喜 EDG 勇夺 2021 英雄联盟全球总决赛冠军
快速排序几种实现方法及其优化
MySQL master-slave synchronization - multiple instances
Preliminary test of glusterfs storage setup
阿里二面:main 方法可以继承吗?
Redisjson: a redis that can store JSON
MySQL主从同步-多实例
CEPH maintenance command understanding









