图的遍历(某谷P3916)

本来以为很水的题
————
结果第一次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;
}

猜你喜欢

转载自www.cnblogs.com/ddddeacde/p/9931547.html
今日推荐