力扣经典题目之->环形链表(判断链表中是否有环)的讲解与实现

一:题目

二:思路讲解

1:采用快慢指针的方法,一个fast指针一次移动两个节点,一个slow指针一次移动一个节点。

2:两个指针从头指针开始往后遍历,如果fast指针或者fast->next 有一个为空,那就代表这不是带环链表。

以上是fast指针为空,代表这是一个偶数个节点的链表,fast1,3,5这样的移动,最后一次会到尾节点的下一个节点,所以fast为空。

以上是 fast->next指针为空,代表这是一个奇数个节点的链表,fast1,3,5这样的移动,最后一次会到尾节点,所以它的next为空。

以上这两种情况都代表这个链表不带环

3:当slow和fast遍历的时候,如果fast和slow相等,就代表该链表带环,步骤如下所示:

a:初识状态

b:开始移动

 

c:继续移动

 

d:两者相等

 

 

相等只会出现在环内的节点,二者会相遇,即slow=fast。

代码展示 :

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值