• 链表经典面试题之二


     今天我们做一道环形链表的题目力扣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;

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

  • 相关阅读:
    linux之shell脚本练习
    fastjson知多少
    费马小定理的两个证明
    哔哩哔哩自动引流软件的运行分享,以及涉及到技术与核心代码分享
    sox音频处理和ffmpeg评测
    EasyCVR视频监控+AI智能分析网关如何助力木材厂安全生产?
    汇编语言实验7:子程序结构设计
    makefile 调试
    系统架构师备考倒计时24天(每日知识点)
    Linux进阶-ipc共享内存
  • 原文地址:https://blog.csdn.net/weixin_67131528/article/details/134354865