码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [数据结构]链表OJ--环形链表判断是否有环(快慢指针法)


    141. 环形链表 - 力扣(LeetCode)

    这里我采用的是快慢指针法,这是我认为最容易理解的方法,这个方法的思路是这样的.

    我们可以定义两个指针一个快一个慢,如果这个链表有环,则快慢指针一定会相遇.

    这里我画图举个例子:

    我们很明显的可以看出,有环链表,快指针和慢指针存在相遇.

    快指针跑得快,慢指针跑得慢。当慢指针和快指针从链表上的同一个节点开始移动时,如果该链表中没有环,那么快指针将一直处于慢指针的前方;如果该链表中有环,那么快指针会先于慢指针进入环,并且一直在环内移动。等到慢指针进入环时,由于快指针的速度快,它一定会在某个时刻与慢指针相遇,即套了慢指针若干圈。

    接下来就让我们的想法实现

    1. /**
    2. * Definition for singly-linked list.
    3. * struct ListNode {
    4. * int val;
    5. * struct ListNode *next;
    6. * };
    7. */
    8. bool hasCycle(struct ListNode *head) {
    9. }

    它默认给我们创建了一个链表,给了这个链表的表头的地址

    我们想可以考虑给的链表为空的情况,而且我们观察例子,我们可以看出存在只有一个头的没有下一个节点的链表,所以我门要对这两种情况进行判断

    1. if(head==NULL||head->next==NULL)
    2. {
    3. return false;
    4. }

    然后我们创建快慢指针:

    1. struct ListNode* slow = head;
    2. struct ListNode* fast = head;

    然后我们让指针跑起来如果最后有一个指针跑到NULL说明,这个链表没有环,如果快慢指针不相等就接着跑,知道两个指针相遇.说明有环

    1. do
    2. {
    3. if (fast == NULL || fast->next == NULL)
    4. {
    5. return false;
    6. }
    7. slow = slow->next;
    8. fast = fast->next->next;
    9. }while (slow != fast);
    10. return true;

    最后组合起来

    1. /**
    2. * Definition for singly-linked list.
    3. * struct ListNode {
    4. * int val;
    5. * struct ListNode *next;
    6. * };
    7. */
    8. bool hasCycle(struct ListNode* head) {
    9. if (head == NULL || head->next == NULL) {
    10. return false;
    11. }
    12. struct ListNode* slow = head;
    13. struct ListNode* fast = head;
    14. do
    15. {
    16. if (fast == NULL || fast->next == NULL)
    17. {
    18. return false;
    19. }
    20. slow = slow->next;
    21. fast = fast->next->next;
    22. }while (slow != fast);
    23. return true;
    24. }

  • 相关阅读:
    IB心理学社会文化介绍
    [LeetCode周赛复盘] 第 326 场周赛20230101
    Hadoop系列——Hadoop集群安装day2-1
    零基础转行网络安全,难度大吗?
    Go-Excelize API源码阅读(二十二)——SetAppProps(appProperties *AppProperties)
    【CoderSay】Code For Better 谷歌开发者之声 - 相遇2022GoogleSummit
    C++类和对象(上)
    【spring Cloud】为啥最后报空指针了?Eureka注册Movie对象不成功?
    SpringBoot整合MongoDB以及副本集、分片集群的搭建
    DNS设置(linux)
  • 原文地址:https://blog.csdn.net/2301_80017277/article/details/136435910
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号