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

相关推荐
夏幻灵11 分钟前
JAVA基础:基本数据类型和引用数据类型
java·开发语言
水力魔方29 分钟前
武理排水管网模拟分析系统应用专题5:模型克隆与并行计算
数据库·c++·算法·swmm
cike_y30 分钟前
Spring-Bean的作用域&Bean的自动装配
java·开发语言·数据库·spring
十八度的天空1 小时前
第01节 Python的基础语法
开发语言·python
OliverH-yishuihan1 小时前
在win10上借助WSL用VS2019开发跨平台项目实例
linux·c++·windows
yue0081 小时前
C# 字符串倒序
开发语言·c#
强子感冒了2 小时前
Java学习笔记:String、StringBuilder与StringBuffer
java·开发语言·笔记·学习
低保和光头哪个先来2 小时前
场景6:对浏览器内核的理解
开发语言·前端·javascript·vue.js·前端框架
小北方城市网2 小时前
Python + 前后端全栈进阶课程(共 10 节|完整版递进式|从技术深化→项目落地→就业进阶,无缝衔接基础课)
大数据·开发语言·网络·python·数据库架构
程序员JerrySUN2 小时前
OP-TEE + YOLOv8:从“加密权重”到“内存中解密并推理”的完整实战记录
android·java·开发语言·redis·yolo·架构