判断图中是否有环

邻接表方式

在邻接表方式中,我们可以使用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;  
}  
相关推荐
小白菜又菜5 小时前
Leetcode 3432. Count Partitions with Even Sum Difference
算法·leetcode
wuhen_n6 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
sin_hielo6 小时前
leetcode 2483
数据结构·算法·leetcode
Xの哲學7 小时前
Linux多级时间轮:高精度定时器的艺术与科学
linux·服务器·网络·算法·边缘计算
大头流矢7 小时前
归并排序与计数排序详解
数据结构·算法·排序算法
油泼辣子多加8 小时前
【信创】算法开发适配
人工智能·深度学习·算法·机器学习
Aaron15888 小时前
AD9084和Versal RF系列具体应用案例对比分析
嵌入式硬件·算法·fpga开发·硬件架构·硬件工程·信号处理·基带工程
laocooon5238578868 小时前
插入法排序 python
开发语言·python·算法
wuhen_n9 小时前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
林shir10 小时前
Java基础1.7-数组
java·算法