码迷,mamicode.com
首页 > 其他好文 > 详细

图的遍历(某谷P3916)

时间:2018-11-08 20:12:48      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:main   std   string   --   问题   ack   ons   tle   amp   

本来以为很水的题
————
结果第一次TLE了两个点
(我还是太菜了)
这个题需要你从编号最大的点倒着来枚举
(太虚假了)
然后就是一个简单的bfs了(相信对在座的大佬来说完全不算问题)

#include<cstdio>
#include<algorithm>
#include<vector>
#include<queue>
#include<cstring>
using namespace std;
const int maxn=1e5+5;
int n,m,u,v;
int ans[maxn];
vector<int>g[maxn];
bool vis[maxn];
void bfs(int v){
    queue<int>q;
    //memset(vis,0,sizeof(vis));
    q.push(v);vis[v]=1;
    while(q.size()){
        int x=q.front();q.pop();
        ans[x]=v;
        for(int i=0;i<g[x].size();i++){
            int u=g[x][i];
            if(!vis[u]){
                vis[u]=1;
                q.push(u);
            }
        }
    }
}
int main(){
    scanf("%d%d",&n,&m);
    for(int i=1;i<=m;i++){
        scanf("%d%d",&u,&v);
        g[v].push_back(u);
    }
    for(int i=n;i>=1;i--){
        if(!vis[i]){
            bfs(i);
        }
    }
    for(int i=1;i<=n;i++){
        printf("%d ",ans[i]);
    }
    return 0;
}

图的遍历(某谷P3916)

标签:main   std   string   --   问题   ack   ons   tle   amp   

原文地址:https://www.cnblogs.com/ddddeacde/p/9931547.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!