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

}

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

相关推荐
charlie1145141911 分钟前
C++ STL Cookbook STL算法
c++·算法·stl·c++20
The博宇12 分钟前
大数据常用的算法--常用的分类算法
大数据·人工智能·算法·分类
2301_7931393332 分钟前
光控资本:新能源汽车持续渗透 充电需求将保持快速增长
leetcode·microsoft·zookeeper·big data·memcached
chenziang136 分钟前
leetcode 热题100 两数之和
算法·leetcode·职场和发展
IT猿手1 小时前
强化学习路径规划:基于SARSA算法的移动机器人路径规划,可以更改地图大小及起始点,可以自定义障碍物,MATLAB代码
android·算法·机器学习·matlab·迁移学习·强化学习·多目标优化
羽墨灵丘1 小时前
排序算法(3):插入排序
算法·排序算法
sc写算法1 小时前
快速排序及两种优化与思考
数据结构·算法·排序算法
为了孩子他娘而奋斗2 小时前
C语言实践作业:游戏与字符处理系统
c语言·算法·游戏
iiiiiankor2 小时前
【LeetCode刷题之路】622.设计循环队列
算法·leetcode·职场和发展·循环队列
麻瓜老宋2 小时前
C语言之为波兰表达式增加函数调用功能
c语言·开发语言·数据结构·算法·链表