题海拾贝:力扣 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;

}

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

相关推荐
leobertlan1 小时前
好玩系列:用20元实现快乐保存器
android·人工智能·算法
青梅橘子皮1 小时前
C语言---指针的应用以及一些面试题
c语言·开发语言·算法
_深海凉_2 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode
被开发耽误的大厨5 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang0073215 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆6 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)7 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野8 小时前
刷题:数组
数据结构·算法
tankeven8 小时前
HJ182 画展布置
c++·算法
CS_Zero10 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机