判断链表中是否有环

如下图,如何判断链表中存在环路呢?

一种简单的方法描述:

  1. 设置两个链表指针p1和p2并指向链表,设置两个记录指针移动次数的变量c1和c2。
  2. 在循环中,p1每次移动2个位置,c1加2;p1每次移动一个位置,c2加1。
  3. 若是两个指针中任何一个值是0(到达链表末尾),则退出并且无环路;否则,判断两个指针值是否相等,如果相等则退出且有环路,否则,继续执行第2步。
相关推荐
2501_9434691518 小时前
【无标题】
数据结构·算法
_codemonster18 小时前
计算机视觉入门到实战系列(八)Harris角点检测算法
python·算法·计算机视觉
Snow_day.18 小时前
有关排列排列组合(1)
数据结构·算法·贪心算法·动态规划·图论
dora18 小时前
【开发火星地平线辅助】智商不够,编程来凑
算法
im_AMBER18 小时前
Leetcode 100 在链表中插入最大公约数
数据结构·c++·笔记·学习·算法·leetcode·链表
Z1Jxxx18 小时前
删除字符串2
开发语言·c++·算法
踩坑记录18 小时前
leetcode hot100 15. 三数之和 medium
算法·leetcode·职场和发展
独自破碎E18 小时前
【二分法】旋转数组的最小数字
数据结构·算法·排序算法
苦藤新鸡18 小时前
9.找到字符串中所有字母异位词
数据结构·c++·算法·力扣
逑之19 小时前
C语言笔记12:C语言内存函数
c语言·笔记·算法