C++算法练习-day10——142.环状链表2

题目来源:. - 力扣(LeetCode)

题目思路分析

题目要求检测一个链表中是否存在环,并返回环的起始节点。这个问题通常被称为"链表中的环检测问题"。为了解决这个问题,我们可以使用快慢指针(也称为Floyd的循环检测算法)或者利用哈希集合(如C++中的unordered_set)来记录已经访问过的节点。这里我们选择后者,因为它相对直观且易于实现。

代码实例:

#include <unordered_set>  
  
// 单链表节点的定义  
struct ListNode {  
    int val;  
    ListNode *next;  
    ListNode(int x) : val(x), next(NULL) {}  
};  
  
class Solution {  
public:  
    ListNode *detectCycle(ListNode *head) {  
        // 使用unordered_set来存储访问过的节点  
        unordered_set<ListNode *> ans;  
          
        // 遍历链表,直到遇到NULL或者发现重复的节点  
        while(head != NULL){  
            // 如果当前节点已经在集合中,说明有环,返回该节点  
            if(ans.count(head)){  
                return head;  
            }  
            // 将当前节点加入集合  
            ans.insert(head);  
            // 移动到下一个节点  
            head = head->next;  
        }  
        // 如果遍历完整个链表都没有发现环,返回NULL  
        return NULL;  
    }  
};

注释详解

  1. 包含头文件#include <unordered_set>,使用哈希集合来存储访问过的节点。
  2. 定义链表节点结构struct ListNode,包含一个整数值val和一个指向下一个节点的指针next
  3. 定义解决方案类class Solution,包含一个公共方法detectCycle,该方法接受链表的头节点head作为参数。
  4. 创建哈希集合unordered_set<ListNode *> ans;,用于存储访问过的节点。
  5. 遍历链表 :使用while循环遍历链表,直到headNULL或者发现重复的节点。
  6. 检查节点是否已访问if(ans.count(head)),如果当前节点已经在集合中,说明有环,返回该节点。
  7. 添加节点到集合ans.insert(head);,将当前节点加入集合。
  8. 移动到下一个节点head = head->next;,继续遍历链表。
  9. 返回结果 :如果遍历完整个链表都没有发现环,返回NULL

知识点摘要

  • 链表:一种常见的数据结构,由一系列节点组成,每个节点包含数据和指向下一个节点的指针。
  • 哈希集合:一种数据结构,可以在平均情况下实现常数时间的插入、删除和查找操作。
  • Floyd的循环检测算法:一种使用快慢指针的算法,用于检测链表中的环。
  • 循环检测:确定链表中是否存在环,并找到环的起始节点。

在这篇文章中,我们讨论了如何使用哈希集合来解决链表中的环检测问题。通过遍历链表并使用哈希集合记录访问过的节点,我们可以有效地检测链表中的环,并找到环的起始节点。这种方法简单直观,易于理解和实现。虽然Floyd的循环检测算法是另一种有效的解决方案,但使用哈希集合的方法在某些情况下可能更加直观和适合。希望这篇文章能够帮助你更好地理解和解决链表中的环检测问题。

相关推荐
Ajiang28247353041 小时前
对于C++中stack和queue的认识以及priority_queue的模拟实现
开发语言·c++
幽兰的天空1 小时前
Python 中的模式匹配:深入了解 match 语句
开发语言·python
Theodore_10224 小时前
4 设计模式原则之接口隔离原则
java·开发语言·设计模式·java-ee·接口隔离原则·javaee
‘’林花谢了春红‘’6 小时前
C++ list (链表)容器
c++·链表·list
----云烟----6 小时前
QT中QString类的各种使用
开发语言·qt
lsx2024066 小时前
SQL SELECT 语句:基础与进阶应用
开发语言
开心工作室_kaic7 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
向宇it7 小时前
【unity小技巧】unity 什么是反射?反射的作用?反射的使用场景?反射的缺点?常用的反射操作?反射常见示例
开发语言·游戏·unity·c#·游戏引擎
武子康7 小时前
Java-06 深入浅出 MyBatis - 一对一模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据仓库·sql·mybatis·springboot·springcloud
转世成为计算机大神7 小时前
易考八股文之Java中的设计模式?
java·开发语言·设计模式