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