8.13日一个简单的拓扑排序

是泡泡 每日一题总教官
云计算领域优质创作者
2022-08-13 20:55:09
加精
class Solution {
public:
    bool canFinish(int n, vector<vector<int>>& p) {
        vector<vector<int>> g(n);
        vector<int> d(n);
        for(auto &i: p)
        {
            int x = i[0], y = i[1];
            g[x].push_back(y);
            d[y]++;
        }
        queue<int> q;
        int ans = 0;
        for(int i = 0; i < n; i++)
            if(!d[i]) q.push(i);
        while(q.size())
        {
            auto t = q.front();
            q.pop();
            ans++;
            for(auto &i: g[t])
                if(--d[i] == 0) q.push(i);
            
        }
        return ans == n;
    }
};

 

...全文
38 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

51,714

社区成员

发帖
与我相关
我的任务
社区描述
和众多高校算法内卷分子,一起学习和交流算法那。浓郁的算法交流氛围,拒绝躺平,有效内卷。加入我们,私信我拉你入核心内卷群。
算法数据结构leetcode 个人社区
社区管理员
  • 执 梗
  • Dream-Y.ocean
  • ღCauchyོꦿ࿐
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

 刷题!

试试用AI创作助手写篇文章吧