社区讨论

AC代码

P5318【深基18.例3】查找文献参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@m4e0yi9x
此快照首次捕获于
2024/12/07 18:21
去年
此快照最后确认于
2024/12/07 18:21
去年
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n,m,ans=0,u,v,vis[100005],f;
vector<int> a[100005];
queue<int> q;
void dfs(int x,int sum)
{
	vis[x]=1;
	cout<<x<<" ";
	if(sum==n) return ;
	for(int i=0;i<a[x].size();i++)
	{
		if(!vis[a[x][i]])
		{     	
			dfs(a[x][i],sum+1);
		}
		
	}
	return ;
}
void bfs(int x)
{
	vis[x]=1;
	q.push(x);
	while(!q.empty())
	{
		int xx=q.front();
		q.pop();
		cout<<xx<<" ";
		for(int i=0;i<a[xx].size();i++)
		{
			if(!vis[a[xx][i]])
			{
				vis[a[xx][i]]=1;
				q.push(a[xx][i]);
			}
		}
	}
	return ;
}
int main()
{
	cin>>n>>m;
	for(int i=1;i<=m;i++)
	{
		cin>>u>>v;
		a[u].push_back(v);
	}
	for(int i=1;i<=n;i++) sort(a[i].begin(),a[i].end());
	dfs(1,0);
	memset(vis,0,sizeof(vis));
	cout<<endl;
	bfs(1);
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...