判断链表中是否有环

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

一种简单的方法描述:

  1. 设置两个链表指针p1和p2并指向链表,设置两个记录指针移动次数的变量c1和c2。
  2. 在循环中,p1每次移动2个位置,c1加2;p1每次移动一个位置,c2加1。
  3. 若是两个指针中任何一个值是0(到达链表末尾),则退出并且无环路;否则,判断两个指针值是否相等,如果相等则退出且有环路,否则,继续执行第2步。
相关推荐
v_for_van7 分钟前
力扣刷题记录7(无算法背景,纯C语言)
c语言·算法·leetcode
先做个垃圾出来………13 分钟前
3640. 三段式数组 II
数据结构·算法
tankeven1 小时前
HJ93 数组分组
c++·算法
Σίσυφος19001 小时前
LM 在 PnP(EPnP / P3P)的应用
算法
陈天伟教授1 小时前
人工智能应用- 人工智能交叉:01. 破解蛋白质结构之谜
人工智能·神经网络·算法·机器学习·推荐算法
LightYoungLee2 小时前
General-behavior interview tutorials
算法
I_LPL2 小时前
day34 代码随想录算法训练营 动态规划专题2
java·算法·动态规划·hot100·求职面试
We་ct3 小时前
LeetCode 105. 从前序与中序遍历序列构造二叉树:题解与思路解析
前端·算法·leetcode·链表·typescript
万象.3 小时前
redis集群算法,搭建,故障处理及扩容
redis·算法·哈希算法
plus4s3 小时前
2月19日(85-87题)
c++·算法