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的循环检测算法是另一种有效的解决方案,但使用哈希集合的方法在某些情况下可能更加直观和适合。希望这篇文章能够帮助你更好地理解和解决链表中的环检测问题。

相关推荐
烤麻辣烫1 分钟前
黑马程序员苍穹外卖(新手) DAY3
java·开发语言·spring boot·学习·intellij-idea
q***48256 分钟前
基于python语言的网页设计(手把手教你设计一个个人博客网站)
开发语言·python
妮妮喔妮6 分钟前
JAVA反射的介绍(优缺点)
java·开发语言
云知谷10 分钟前
【软件测试】《集成测试全攻略:Mock/Stub 原理 + Postman/JUnit/TestNG 实战》
c语言·开发语言·c++·软件工程·团队开发
qq_225891746625 分钟前
基于Python+Django餐饮评论大数据分析与智能推荐系统 毕业论文
开发语言·后端·python·信息可视化·数据分析·django
普通网友35 分钟前
分布式锁服务实现
开发语言·c++·算法
普通网友37 分钟前
移动语义在容器中的应用
开发语言·c++·算法
电摇小人1 小时前
科学备赛今年NOIP!!
java·开发语言
2301_803554521 小时前
每日做面经-25.11.16
开发语言
teacherlg1 小时前
Source Insight 乱码问题解决
c++·乱码·编码·sourceinsight