社区讨论
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 条回复,欢迎继续交流。
正在加载回复...