判断图中是否有环

邻接表方式

在邻接表方式中,我们可以使用DFS和"访问状态"数组(或集合)来追踪节点。当DFS尝试访问一个已经访问过的节点(即已经在递归栈中的节点)时,我们就可以确定图中存在环。

cpp 复制代码
#include <vector>  
#include <unordered_set>  
  
bool dfsUtil(int node, const std::vector<std::vector<int>>& graph, std::unordered_set<int>& visited, std::unordered_set<int>& recursionStack) {  
    if (visited.find(node) != visited.end()) {  
        return false; // 如果已经访问过,但不是在递归栈中,说明没有环  
    }  
    if (recursionStack.find(node) != recursionStack.end()) {  
        return true; // 如果在递归栈中,说明存在环  
    }  
  
    visited.insert(node);  
    recursionStack.insert(node);  
  
    for (int neighbor : graph[node]) {  
        if (dfsUtil(neighbor, graph, visited, recursionStack)) {  
            return true;  
        }  
    }  
  
    recursionStack.erase(node); // 回溯,移出递归栈  
    return false;  
}  
  
bool isCyclic(const std::vector<std::vector<int>>& graph) {  
    std::unordered_set<int> visited, recursionStack;  
    int V = graph.size();  
  
    for (int node = 0; node < V; ++node) {  
        if (!visited.count(node) && dfsUtil(node, graph, visited, recursionStack)) {  
            return true;  
        }  
    }  
  
    return false;  
}  

邻接矩阵的方式

cpp 复制代码
#include <vector>  
#include <unordered_set>  
  
bool dfsUtil(int node, const std::vector<std::vector<int>>& adjMatrix, std::unordered_set<int>& visited, std::unordered_set<int>& recursionStack) {  
    if (visited.find(node) != visited.end()) {  
        return false; // 如果已经访问过,但不是在递归栈中,说明没有环  
    }  
    if (recursionStack.find(node) != recursionStack.end()) {  
        return true; // 如果在递归栈中,说明存在环  
    }  
  
    visited.insert(node);  
    recursionStack.insert(node);  
  
    int V = adjMatrix.size();  
    for (int neighbor = 0; neighbor < V; ++neighbor) {  
        if (adjMatrix[node][neighbor] && dfsUtil(neighbor, adjMatrix, visited, recursionStack)) {  
            return true;  
        }  
    }  
  
    recursionStack.erase(node); // 回溯,移出递归栈  
    return false;  
}  
  
bool isCyclicMatrix(const std::vector<std::vector<int>>& adjMatrix) {  
    std::unordered_set<int> visited, recursionStack;  
    int V = adjMatrix.size();  
  
    for (int node = 0; node < V; ++node) {  
        if (!visited.count(node) && dfsUtil(node, adjMatrix, visited, recursionStack)) {  
            return true;  
        }  
    }  
  
    return false;  
}  
相关推荐
SilentSamsara18 分钟前
生成器完全指南:`yield` 与惰性求值的工程价值
linux·开发语言·python·算法·机器学习·青少年编程
玛卡巴卡ldf26 分钟前
【LeetCode 手撕算法】(二分查找)搜索插入位置、搜索二维矩阵、查找数组相同的所有位置、搜索旋转排序数组、旋转升序数组的最小值
数据结构·算法·leetcode
谷雨不太卷8 小时前
进程的状态码
java·前端·算法
散峰而望8 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德8 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya8 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦8 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
挽星安9 小时前
代码随想录算法训练营第五十天|卡码网 99 岛屿数量、卡码网 100 最大岛屿的面积
算法
葫三生9 小时前
《论三生原理》系列构建文理同构的认知体系?
人工智能·科技·深度学习·算法·机器学习·transformer
多加点辣也没关系9 小时前
数据结构与算法|第六章:队列
数据结构·算法·队列