LeetCode210. Course Schedule II——拓扑排序

文章目录

一、题目

There are a total of numCourses courses you have to take, labeled from 0 to numCourses - 1. You are given an array prerequisites where prerequisites[i] = [ai, bi] indicates that you must take course bi first if you want to take course ai.

For example, the pair [0, 1], indicates that to take course 0 you have to first take course 1.
Return the ordering of courses you should take to finish all courses. If there are many valid answers, return any of them. If it is impossible to finish all courses, return an empty array.

Example 1:

Input: numCourses = 2, prerequisites = [[1,0]]
Output: [0,1]
Explanation: There are a total of 2 courses to take. To take course 1 you should have finished course 0. So the correct course order is [0,1].
Example 2:

Input: numCourses = 4, prerequisites = [[1,0],[2,0],[3,1],[3,2]]
Output: [0,2,1,3]
Explanation: There are a total of 4 courses to take. To take course 3 you should have finished both courses 1 and 2. Both courses 1 and 2 should be taken after you finished course 0.
So one correct course order is [0,1,2,3]. Another correct ordering is [0,2,1,3].
Example 3:

Input: numCourses = 1, prerequisites = []
Output: [0]

Constraints:

1 <= numCourses <= 2000
0 <= prerequisites.length <= numCourses * (numCourses - 1)
prerequisites[i].length == 2
0 <= ai, bi < numCourses
ai != bi
All the pairs [ai, bi] are distinct.

二、题解

class Solution {
   
public:
    vector<int> findOrder(int numCourses, vector<vector<int>>& prerequisites) {
   
        vector<vector<int>> graph;
        for(int i = 0;i < numCourses;i++){
   
            graph.push_back({
   });
        }
        vector<int> indegree(numCourses,0);
        for(auto edge:prerequisites){
   
            graph[edge[1]].push_back(edge[0]);
            indegree[edge[0]]++;
        }
        vector<int> res;
        queue<int> q;
        for(int i = 0;i < indegree.size();i++){
   
            if(indegree[i] == 0) q.push(i);
        }
        while(!q.empty()){
   
            int e = q.front();
            q.pop();
            res.push_back(e);
            int size = graph[e].size();
            for(int i = 0;i < size;i++){
   
                indegree[graph[e][i]]--;
                if(indegree[graph[e][i]] == 0) q.push(graph[e][i]);
            }
        }
        if(res.size() == numCourses) return res;
        else return {
   };
    }
};

相关推荐

  1. LeetCode210. Course Schedule II——拓扑排序

    2024-02-07 15:02:02       46 阅读
  2. leetcode课程表-207-拓扑排序

    2024-02-07 15:02:02       52 阅读
  3. LeetCode207、210 课程表(图 dfs 拓扑排序)

    2024-02-07 15:02:02       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-07 15:02:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-07 15:02:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-02-07 15:02:02       82 阅读
  4. Python语言-面向对象

    2024-02-07 15:02:02       91 阅读

热门阅读

  1. 小程序:windows下C++调用打印机过程简介

    2024-02-07 15:02:02       55 阅读
  2. 傅里叶变换在图像处理中的应用

    2024-02-07 15:02:02       54 阅读
  3. C&C++内存泄露和检测

    2024-02-07 15:02:02       49 阅读
  4. LeetCode //C - 875. Koko Eating Bananas

    2024-02-07 15:02:02       48 阅读
  5. C语言---—————— 快速创建指定个数的文件

    2024-02-07 15:02:02       43 阅读
  6. 2 进程(上)

    2024-02-07 15:02:02       48 阅读
  7. LeetCode树总结

    2024-02-07 15:02:02       54 阅读
  8. mysql order by 排序原理

    2024-02-07 15:02:02       41 阅读
  9. 每月AI科研动向(2024年1月)

    2024-02-07 15:02:02       42 阅读
  10. 如何快速上手Vue框架

    2024-02-07 15:02:02       63 阅读
  11. 解决 python CV2 imread读取中文文件名的问题

    2024-02-07 15:02:02       54 阅读
  12. 达梦数据库适配Springboot+MybatisPlus+达梦数据库

    2024-02-07 15:02:02       56 阅读
  13. 渗透测试工具库总结(全网最全)

    2024-02-07 15:02:02       80 阅读
  14. redis相关问题

    2024-02-07 15:02:02       43 阅读
  15. UI自动化之Poco常用断言方式

    2024-02-07 15:02:02       53 阅读