• 判断图中是否有环


    邻接表方式

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

    #include   
    #include   
      
    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;  
    }  
    

    邻接矩阵的方式

    #include   
    #include   
      
    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;  
    }  
    
  • 相关阅读:
    Unity入门02——Unity工作原理
    Android 设计模式六大原则
    Linux aarch64交叉编译之 cryptopp加密库
    jdk8之Optional类判空处理
    C++:用函数模板排列数组
    Qt学习20 Qt 中的标准对话框(中)
    【Java自定义工具类】百分比计算工具类以及计算相关的问题(138)
    Unity UGUI(一)基础组件
    HC-SR501传感器制作一个报警系统
    非洲美食多样性而丰富多彩
  • 原文地址:https://blog.csdn.net/lianghudream/article/details/139401776