【力扣: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;
    }
};
相关推荐
鱼鱼不愚与3 小时前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
博客18006 小时前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴8 小时前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
复杂网络8 小时前
论最小 Agent 计算机的形态
算法
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
众少成多积小致巨1 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
猿人谷1 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络1 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络1 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4001 天前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法