图的遍历(某谷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;
}

posted @ 2018-11-08 19:56  Dzzzzzz  阅读(167)  评论(1编辑  收藏  举报