题海拾贝:力扣 141.环形链表

Hello大家好!很高兴我们又见面啦!给生活添点passion,开始今天的编程之路!

我的博客: <但凡.

我的专栏: 《编程之路》《数据结构与算法之美》《题海拾贝》

欢迎点赞,关注!

1、题目

2、题解(快慢指针)

我们可以定义两个指针,刚开始时都指向这个链表的头节点,然后让快指针每次走两个节点,慢指针每次走一个节点。如果有环状链表存在,那快慢指针一定会相遇。倘若没有,快指针一定会先走到头,快指针下一个节点是空或者他自己是空时,返回假。

cpp 复制代码
/**
 * 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;
    if(head==NULL||head->next==NULL) return false;

    while( fast!=NULL && slow!=NULL && fast->next!=NULL){
        fast=fast->next->next;
        slow=slow->next;
        if( fast==slow ) return true;
    }
    return false;

}

好了,今天的内容就分享到这,我们下期再!

相关推荐
国科安芯18 小时前
AS32S601商业航天级抗辐照MCU芯片:架构设计与技术特性研究
单片机·嵌入式硬件·算法·安全·架构·risc-v
菜菜的顾清寒19 小时前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论
圣保罗的大教堂19 小时前
leetcode 2657. 找到两个数组的前缀公共数组 中等
leetcode
名字不好奇19 小时前
大模型的思考模式:它真的在“想“吗?
人工智能·算法
Run_Teenage19 小时前
算法模板:输入输出,并查集
java·开发语言·算法
高一学习c++会秃头吗19 小时前
操作系统内存块分配算法
算法
洛水水19 小时前
【力扣100题】57.合并区间
算法·leetcode
圣保罗的大教堂19 小时前
leetcode 33. 搜索旋转排序数组 中等
leetcode
玉树临风ives19 小时前
atcoder ABC 458 题解
数据结构·c++·算法
AKA__Zas19 小时前
芝士算法 (双指针篇2.0)
java·数据结构·leetcode·学习方法