判断图中是否有环

邻接表方式

在邻接表方式中,我们可以使用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;  
}  
相关推荐
RTC老炮15 分钟前
webrtc弱网-RobustThroughputEstimator源码分析与算法原理
网络·算法·webrtc
听风吹等浪起31 分钟前
分类算法-逻辑回归
人工智能·算法·机器学习
敲代码的嘎仔32 分钟前
JavaWeb零基础学习Day2——JS & Vue
java·开发语言·前端·javascript·数据结构·学习·算法
yacolex1 小时前
3.3_数据结构和算法复习-栈
数据结构·算法
茉莉玫瑰花茶1 小时前
动态规划 - 两个数组的 dp 问题
算法·动态规划
微笑尅乐1 小时前
从暴力到滑动窗口全解析——力扣8. 字符串转换整数 (atoi)
算法·leetcode·职场和发展
火花怪怪2 小时前
LaMer结晶动力学模型
算法
legendary_bruce2 小时前
【22.2 增强决策树】
算法·决策树·机器学习
老马啸西风3 小时前
力扣 LC27. 移除元素 remove-element
算法·面试·github
数智顾问3 小时前
中秋特别篇:使用QtOpenGL和着色器绘制星空与满月——从基础框架到光影渲染
算法