Leetcode 141 Linked List Cycle and Leetcode 142 Linked List Cycle II

题目链接

https://leetcode.com/problems/linked-list-cycle/
https://leetcode.com/problems/linked-list-cycle-ii/

题意

给定一个环形链表,求找到链表的环的位置,返回一个指针(以Leetcode 142为例)

题解

首先判断是否有环。可以用快慢指针来确定,由于快的那个指针一直在环中移动,慢的指针每次移动一步,二者一定会相遇,如果能相遇则说明有环。第二步假设从链表头到环的起点距离为a,相遇点为c,那么一定满足a+c+kb = 2(a+c),则满足a+c = kb,也就是说如果一个指针从链表头开始,另一个指针从相遇点开始走,那么两者相遇的点就是环的起点。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *detectCycle(ListNode *head) {
        bool hasCycle = false;
        ListNode *p1 = head;
        ListNode *p2 = head;
        while (p1 != nullptr && p1->next != nullptr) {
            p1 = p1->next->next;
            p2 = p2->next;
            if(p1 == p2) {
                hasCycle = true;
                break;
            }
        }
        if(hasCycle) {
            ListNode *p3 = head;
            while( p1 != p3) {
                p1 = p1->next;
                p3 = p3->next;
            }
            return p1;
        } 
        return nullptr;
    }
};

时间复杂度: O ( n ) O(n) O(n) n是链表的长度

空间复杂度: O ( 1 ) O(1) O(1)

相关推荐
qiuiuiu4137 分钟前
CPrimer Plus第十六章C预处理器和C库总结2-qsort函数
java·c语言·算法
JuneXcy1 小时前
C++知识点总结用于打算法
c++·算法·图论
zhuzhuxia⌓‿⌓3 小时前
线性表的顺序和链式存储
数据结构·c++·算法
未知陨落3 小时前
LeetCode:95.编辑距离
算法·leetcode
杨小码不BUG3 小时前
小鱼的数字游戏:C++实现与算法分析(洛谷P1427)
c++·算法·数组·信奥赛·csp-j/s
高山有多高3 小时前
栈:“后进先出” 的艺术,撑起程序世界的底层骨架
c语言·开发语言·数据结构·c++·算法
YouEmbedded4 小时前
解码查找算法与哈希表
数据结构·算法·二分查找·散列表·散列查找·线性查找
greentea_20134 小时前
Codeforces Round 65 C. Round Table Knights(71)
c语言·开发语言·算法
小秋学嵌入式-不读研版4 小时前
C61-结构体数组
c语言·开发语言·数据结构·笔记·算法
可触的未来,发芽的智生4 小时前
触摸未来2025.10.04:当神经网络拥有了内在记忆……
人工智能·python·神经网络·算法·架构