题解 | #【模板】拓扑排序#

【模板】拓扑排序

http://www.nowcoder.com/practice/88f7e156ca7d43a1a535f619cd3f495c

采用广度优先遍历
有个坑,最后必须不能有空白符' ',否则会算错误

#include <iostream>
#include <vector>
#include <queue>
using namespace std;

int main()
{
    int n,m;
    cin >> n >> m;
    vector<bool> marked(n + 1,false);
    vector<int> in(n + 1, 0);
    vector<vector<int>> out(n + 1);
    for(int i = 0; i < m; ++i)
    {
        int from, to;
        cin >> from;
        cin >> to;
        out[from].push_back(to);
        ++in[to];
    }
    queue<int> wait;
    vector<int> res;
    for(int v = 1; v <= n; ++v)
    {
        if(in[v] == 0)  wait.push(v);
    }
    while(!wait.empty())
    {
        int v = wait.front();
        wait.pop();
        res.push_back(v);
        for(auto u : out[v])
        {
            if(--in[u] == 0)  wait.push(u);
        }
    }
    if(res.size() == n)
    {
        for(int i = 0; i < n; ++i)
        {
            cout << res[i];
            if(i != n - 1) cout << ' ';
        }
    }
    else
    {
        cout << -1;
    }
}
全部评论
marked容器没用却声明了,所以是不是忘记删掉了
点赞 回复 分享
发布于 08-21 16:21 河南

相关推荐

扭转乾坤_:现在企业都是学华为,一直通过丢池子里,最后捞
点赞 评论 收藏
分享
7 收藏 评论
分享
牛客网
牛客企业服务