码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 链表经典面试题之二


     今天我们做一道环形链表的题目力扣141题https://leetcode.cn/problems/linked-list-cycle/

     这道题让我们分析链表中是否存环,存在的话返回true,不存在返回false。首先看到这道题我们要捋顺思路,怎么才能达到它要的效果?要找出是否存在一个环,那么我们能不能看看尾结点的下一个结点是不是之前出现过的结点呢?我们在仔细想一想,如果有环的话,存在尾结点吗?当然不存在,如果环存在的话,就没有尾结点,都已经叫尾结点了那肯定就是最后一个结点。所以我们不妨改变思路,用快慢双指针的方式做这道题目。

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

    我们定义fast一次走两步,slow一次走一步,如果有环fast肯定先进环一直在换里面转,当slow进环的时候两个指针距离相差为N,而fast和slow每走一步,距离就减少1,总会存在,距离为0的情况,当fast=slow的时候,存在环,否则不存在;

     

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

     但是这个while循环的条件怎么判断呢?什么时候循环停下?fast走的快,当fast走到尾为空的时候停下,有人会有疑问,不是有环的时侯链表没有尾吗?是的,但是我们这个判断是循环停下的条件,如果循环没有进循环时不时就是没有环就直接返回false了呢?

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

    这样就结束了吗?我们运行会发现它报了一个空指针的错误

    到底哪里出现空指针了呢?我们想一下当时fast一次走两步,fast=fast->next->next,我们只判断了当fast==NULL的时候循环停止,是不是忽略掉fast->next的时候到空了呢?这个时候,fast->next还能指向next吗?所以,这个循环应该是while(fast&&fast->next)才可以。

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

    当我们这样写完,运行就通过啦

  • 相关阅读:
    谈谈IC、ASIC、SoC、MPU、MCU、CPU、GPU、DSP、FPGA、CPLD的简介
    Cookie 和 Session
    gici-open示例数据运行(ground_truth坐标的转换)
    图的遍历 深度优先遍历(爱思创)
    每日一题——LeetCode1544.整理字符串
    tomcat注册为服务
    OpenCV:实现图像的负片
    人工智能基础_机器学习033_多项式回归升维_多项式回归代码实现_非线性数据预测_升维后的数据对非线性数据预测---人工智能工作笔记0073
    【历年IJCAI论文下载(含IJCAI2022)】图神经网络(GNN)(多行为推荐、多模态食谱表示学习、同质图表示学习)
    [模块化编写驱动控制LED灯]
  • 原文地址:https://blog.csdn.net/weixin_67131528/article/details/134354865
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号