题解 | c++#判断链表中是否有环#

判断链表中是否有环

https://www.nowcoder.com/practice/650474f313294468a4ded3ce0f7898b9

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    bool hasCycle(ListNode *head) {
        ListNode *fast=new ListNode(66);//双指针
        ListNode *slow=new ListNode(66);
        fast=slow=head;
        while (fast!=NULL&&fast->next!=NULL) {//next存在,则可以找到next->next,避免next->next越界
            fast=fast->next->next;//一个跑得快,一个跑得慢,如果有循环,必定会相遇
            slow=slow->next;//fast更快,fast不越界,则slow一定不越界
            if(slow==fast){
                return true;
            }
        }
        return false;
    }
};

全部评论

相关推荐

asdasdasda...:19岁,不容易啊可能升个本会好点,现在学历歧视太严重了
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-11 11:24
大家还是用ai改吧,我心疼得要死,就当花钱买教训吧,人家直接拿完钱就跑路了
程序员小白条:简历修改700....神奇,又不是帮你面试,咋的,简历修改从双非变92了还是没实习变成有大厂实习了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务