环形链表Ⅱ-力扣

第一种解法时哈希表,set在使用insert插入时,会返回一个pair,如果pair的值为0,则插入失败,那么返回这个插入失败的节点,就是入环的第一个节点,代码如下:

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) {
        unordered_set<ListNode*> set;
        auto cur = head;
        while(cur != NULL){
            if(set.insert(cur).second){
                cur = cur->next;
            }else{
                return cur;
            }
        }
        return NULL;
    }
};

第二种快慢指针的写法,数学推导相当精妙,推到过程可以参考代码随想录-环形链表Ⅱ

参考代码:

cpp 复制代码
class Solution {
public:
    ListNode *detectCycle(ListNode *head) {
        ListNode *slow = head, *fast = head;
        while (fast != nullptr) {
            slow = slow->next;
            if (fast->next == nullptr) {
                return nullptr;
            }
            fast = fast->next->next;
            if (fast == slow) {
                ListNode *ptr = head;
                while (ptr != slow) {
                    ptr = ptr->next;
                    slow = slow->next;
                }
                return ptr;
            }
        }
        return nullptr;
    }
};
相关推荐
zhangx1234_6 分钟前
C语言题目1
c语言·开发语言·数据结构
Swift社区8 分钟前
LeetCode 412 - Fizz Buzz
算法·leetcode·职场和发展
小年糕是糕手12 分钟前
【C/C++刷题集】二叉树算法题(一)
c语言·数据结构·c++·算法·leetcode·学习方法·改行学it
im_AMBER9 小时前
数据结构 09 二叉树作业
数据结构·笔记·学习
l1t11 小时前
利用DeepSeek修改数据结构提升求解集合程序效率
数据结构·python·deepseek
先做个垃圾出来………12 小时前
偏移量解释
数据结构·算法
Dream it possible!12 小时前
LeetCode 面试经典 150_链表_旋转链表(64_61_C++_中等)
c++·leetcode·链表·面试
立志成为大牛的小牛13 小时前
数据结构——三十三、Dijkstra算法(王道408)
数据结构·笔记·学习·考研·算法·图论
坚持编程的菜鸟14 小时前
LeetCode每日一题——Pow(x, n)
c语言·算法·leetcode
小王C语言15 小时前
哈希表实现
数据结构·哈希算法·散列表