力扣HOT100(25)环形链表

解法一:哈希表法

哈希表具有唯一性。记录所有访问过的节点内存地址。

每访问一个节点,先检查其是否已存在在哈希表里。

若存在,则说明链接有环。若不存在 则继续 直到遍历至nullptr仍然无环。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    bool hasCycle(ListNode *head) {
        unordered_set<ListNode*> seen;//哈希表
        while(head!=nullptr){
            if(seen.count(head)){//先检查head这个节点是否在seen中有
                return true;
            }
            seen.insert(head);//如果没有 那就把head放到seen中
            //然后head前移
            head = head->next;
        }
        return false;
    }
};

法二 :快慢指针法 Floyd 判圈算法,面试标准答案

核心原理

利用两个速度不同的指针在链表上遍历:

  • 慢指针(slow):每次移动 1 步
  • 快指针(fast):每次移动 2 步
两种情况的必然性
  1. 链表无环 :快指针速度更快,必然先到达链表尾部(fast == nullptrfast->next == nullptr),两指针永远不会相遇
  2. 链表有环:快指针先进入环内循环,慢指针随后进入环内。由于快指针相对慢指针的速度为 1 步 / 次,两者的距离会每次缩短 1 步,最终必然在环内相遇
cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    bool hasCycle(ListNode *head) {
       //法二 快慢指针法:
       //如果不是回环 快指针先走完就知道了不是了
       //如果是回环  因为快指针走的快 所以快指针和慢指针肯定会相遇

       //空或者单链表 肯定不是
    if (head == nullptr || head->next == nullptr) {
            return false;
        }
      
      

       ListNode* fast = head->next;
       ListNode *slow = head;
       while(fast!=slow){
    
        if(fast == nullptr|| fast->next == nullptr){
            return false;
        }
            fast = fast->next->next;
        slow = slow->next;

      
       } 
        return true;
    }
};
相关推荐
折哥的程序人生 · 物流技术专研1 天前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
想吃火锅10051 天前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
云絮.1 天前
数据库操作
数据库·mysql·算法·oracle
小林ixn1 天前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫1 天前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
菜鸟‍1 天前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
退休倒计时1 天前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript
popcorn_min1 天前
Digits 手写数字识别:随机森林多分类 + 像素级特征热力图
算法·随机森林·分类
liulilittle1 天前
拥塞控制:排水终止的两种决策:OR 与 AND
网络·tcp/ip·计算机网络·算法·信息与通信·tcp·通信
weixin_307779131 天前
从脚本执行到智能体协作:AI辅助测试能力的范式重构
运维·开发语言·人工智能·算法·测试用例