【力扣:207,210,310】拓扑排序

cpp 复制代码
class Solution {
    vector<vector<int>>tmp;
    vector<int>index;
public:
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        tmp.resize(numCourses);
        index.resize(numCourses);
        for(auto&i:prerequisites){
            tmp[i[1]].emplace_back(i[0]);
            index[i[0]]++;
        }
        queue<int>que;
        for(int i=0;i<numCourses;i++){
            if(!index[i]) que.emplace(i);
        }
        int count=0;
        while(!que.empty()){
            count++;
            int n=que.front();
            que.pop();
            for(int i:tmp[n]){
                if(--index[i]==0) que.emplace(i);
            }
        }
        return count>=numCourses;
    }
};
cpp 复制代码
class Solution {
    vector<vector<int>>map;
    vector<int>index;
public:
    vector<int> findOrder(int numCourses, vector<vector<int>>& prerequisites) {
        map.resize(numCourses);
        index.resize(numCourses);
        for(auto& i:prerequisites){
            map[i[1]].push_back(i[0]);
            index[i[0]]++;
        }
        vector<int>res;
        for(int i=0;i<numCourses;i++) if(!index[i]) res.push_back(i);
        for(int i=0;i<res.size();i++){
            for(int j:map[res[i]]){
                if(!--index[j]){
                    res.push_back(j);
                }
            }
        }
        if(res.size()<numCourses) return {};
        return res;
    }
};

从叶子节点不断向上拓扑,直到剩下至多2个节点作为根节点

cpp 复制代码
class Solution {
public:
    vector<int> findMinHeightTrees(int n, vector<vector<int>>& edges) {
        if(n==1) return {0};
        vector<vector<int>>tree(n);
        vector<int>tmp(n);
        for(auto& i:edges){
            tree[i[0]].push_back(i[1]);
            tree[i[1]].push_back(i[0]);
            tmp[i[0]]++;
            tmp[i[1]]++;
        }
        queue<int>que;
        for(int i=0;i<n;i++){
            if(tmp[i]==1) que.push(i);
        }
        for(int cur=n;cur>2;){
            int size=que.size();
            cur-=size;
            while(size--){
                int fr=que.front();
                que.pop();
                for(int i:tree[fr]){
                    if(--tmp[i]==1) que.push(i);
                }
            }
        }
        vector<int>res;
        while(!que.empty()){
            res.push_back(que.front());
            que.pop();
        } 
        return res;
    }
};
相关推荐
xlp666hub几秒前
Leetcode第七题:用C++解决接雨水问题
c++·leetcode
CoovallyAIHub25 分钟前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
肆忆_1 小时前
实战复盘:手写 C++ 虚拟机的高性能并行 GC (Thread Pool + Work Stealing)
c++
肆忆_1 小时前
虚函数进阶答疑:把上一篇博客评论区里最容易卡住的问题,一次追到底
c++
颜酱13 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
saltymilk18 小时前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
zone773918 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub21 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉