dfstle了第八个点求助!!!
查看原帖
dfstle了第八个点求助!!!
230857
鹿目圆楼主2021/7/2 16:14
#include<bits/stdc++.h>
using namespace std;
vector<int>tu[114514];
bool vis[114514];
int mem[114514];
int a,b;
int n,m;
int maxn;
void dfs(int x)
{
	if(mem[x])
	{
		maxn=max(maxn,mem[x]);
		return;
	}
	maxn=max(maxn,x);
	for(int i=0;i<tu[x].size();i++)
	{
		if(vis[tu[x][i]]==0)
		{
			vis[x]=1;
			dfs(tu[x][i]);
		}
	}
}
int main()
{
	cin>>n>>m;
	for(int i=1;i<=m;i++)
	{
		cin>>a>>b;
		tu[a].push_back(b);
	}
	for(int i=1;i<=n;i++)
	{
		dfs(i);
		mem[i]=maxn;
		cout<<maxn<<" ";
		maxn=0;
		memset(vis,0,sizeof(vis));
	}
}
2021/7/2 16:14
加载中...