环形链表笔记(自用)

环形链表



不管怎么样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;
}

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

相关推荐
靠沿4 分钟前
Java数据结构初阶——堆与PriorityQueue
java·开发语言·数据结构
禾叙_8 分钟前
HashMap
java·数据结构·哈希算法
阿赵3D17 分钟前
JavaScript学习笔记——11、正则表达式
javascript·笔记·学习·正则表达式
代码or搬砖24 分钟前
JVM学习笔记
jvm·笔记·学习
Lv11770081 小时前
初识Visual Studio中的 WinForm
开发语言·ide·笔记·c#·visual studio
zcbdandan1 小时前
JNA内存对齐导致的结构体数组传输错误
数据结构·算法
张紫娃1 小时前
日语中的音调
笔记
SatoshiGogo1 小时前
强化学习笔记
笔记
wdfk_prog2 小时前
[Linux]学习笔记系列 -- [fs]libfs
linux·笔记·学习
持梦远方2 小时前
持梦行文本编辑器(cmyfEdit):架构设计与十大核心功能实现详解
开发语言·数据结构·c++·算法·microsoft·visual studio