Giving Awards

Giving Awards

https://ac.nowcoder.com/acm/problem/110438

思路:

因为给定的是个有向图,所以一定有解,构造方案就是把这个u当前它欠钱的人先安排好,然后直接输出方案就是一组解了...其实就是按dfs序统计即可啦...

代码:

#include <bits/stdc++.h>
using namespace std;
const int N=1e5;
vector<int>g[N];
int id,ans[N],use[N];
void dfs(int u)
{
    if(use[u])    return;
    use[u]=true;
    for(int v:g[u])
        if(!use[v])    dfs(v);
    ans[++id]=u;
}
int main()
{
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=m;i++)
    {
        int u,v;
        cin>>u>>v;
        g[u].push_back(v);
    }
    for(int i=1;i<=n;i++)
        if(!use[i])
            dfs(i);
    for(int i=1;i<=n;i++)    cout<<ans[i]<<' ';
    puts("");
    return 0;
}

应该是高质量的题解.

全部评论

相关推荐

面了100年面试不知...:小天才g了,但是天才还在
我的求职进度条
点赞 评论 收藏
分享
合适才能收到offe...:项目岗是什么岗?我看你有段好像跟策划运营相关,如果找运营的话第三段经历写详细点儿。 个人建议是把自我评价删了换成专业技能放在工作经验上或者下面。学生会那个也可以删,把第一个包装成店铺运营,写4-6给点。第三个也是写4-6个点。注意工作内容➕部分数据。 投递的时候BOS招呼用语改一下,换成我有xx工作经验,熟练掌握xx技能样式,也可以简历截图然后直接发送。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务