当前位置:   article > 正文

[链表OJ题 7] 环形链表

[链表OJ题 7] 环形链表

目录

题目来源:

代码实现:

思路分析:

实现过程:


题目来源:

力扣 141. 环形链表

题目描述

代码实现:

  1. bool hasCycle(struct ListNode* head) {
  2. struct ListNode* fast = head, * slow = head;
  3. while (fast && fast->next)
  4. {
  5. fast = fast->next->next;
  6. slow = slow->next;
  7. if (fast == slow)
  8. return true;
  9. }
  10. return false;
  11. }

思路分析:

本题是要看链表是否成环,那我们就定义快、慢两个指针,快指针一次走两步,慢指针一次走一步。如果链表是成环的,快指针一定就可以追赶上慢指针,重合后就是成环的;如果链表不成环,那我们的快指针就会走到空。

实现过程:

1、使用快慢指针,初始化都指向原链表的头,慢指针一次走一步,快指针一次走两步;

2、在循环的时候我们加上一条判断语句,fast == slow 时,就说明链表是成环的;

3、如果快指针走到了空,或者快指针的 next 为空时,那就说明链表是不成环的。

*** 本篇结束 ***

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/655914
推荐阅读
相关标签
  

闽ICP备14008679号