环形链表笔记(自用)

环形链表



不管怎么样slow最多走半圈了,

快慢指针slow走一步,fast走两步最合适,因为假设fast和slow相差n每一次他们前进,就会相差n-1步,这样他们一定会相遇,如果是环形链表的话。
代码

c 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
bool hasCycle(struct ListNode *head) {
    struct ListNode *fast=head;
    struct ListNode *slow=head;
    while(fast && fast->next)
    {
        slow=slow->next;
        fast=fast->next->next;
        if(fast == slow)
        {
            return true;
        }
    }
    return false;
}

自用笔记,文章质量不行!!!

相关推荐
xw-busy-code14 分钟前
sass学习笔记整理
笔记·学习·sass
㓗冽8 小时前
8皇后·改-进阶题16
数据结构
x_xbx9 小时前
LeetCode:148. 排序链表
算法·leetcode·链表
xuhaoyu_cpp_java9 小时前
过滤器与监听器学习
java·经验分享·笔记·学习
LegendNoTitle9 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
月落归舟10 小时前
帮你从算法的角度来认识数组------( 二 )
数据结构·算法·数组
Oll Correct11 小时前
实验八:验证以太网交换机的生成树协议STP
网络·笔记
_李小白12 小时前
【OSG学习笔记】Day 2: Hello Cow
笔记·学习
Wave84512 小时前
数据结构—树
数据结构