图的遍历(某谷P3916)

Posted ddddeacde

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了图的遍历(某谷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;
}

以上是关于图的遍历(某谷P3916)的主要内容,如果未能解决你的问题,请参考以下文章

P3916 图的遍历 反向建图+DFS

ACM入门之图论习题

求图的深度优先遍历程序 c语言版

Copy自某谷题解,有删改P2346 四子连棋

图的深度优先遍历DFS和广度优先遍历BFS(邻接矩阵存储)超详细完整代码进阶版

22-1图的遍历的源代码