判断图中是否有环

邻接表方式

在邻接表方式中,我们可以使用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;  
}  
相关推荐
小学生的信奥之路3 分钟前
洛谷P3817题解:贪心算法解决糖果分配问题
c++·算法·贪心算法
你知道网上冲浪吗1 小时前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者2 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy3 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub3 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
huangzixuan10073 小时前
08.18总结
算法·深度优先·图论
逆向菜鸟4 小时前
【摧毁比特币】椭圆曲线象限细分求k-陈墨仙
python·算法
DolphinDB4 小时前
DolphinDB 回测插件快速上手
算法
利刃大大4 小时前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题
武大打工仔4 小时前
用 Java 复现哲学家就餐问题
算法