社区讨论

80分,实在找不出错误了

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

讨论操作

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

当前回复
5 条
当前快照
1 份
快照标识符
@luxd0img
此快照首次捕获于
2024/04/13 08:29
2 年前
此快照最后确认于
2024/04/13 10:42
2 年前
查看原帖
玄关
CPP
#include<bits/stdc++.h>
using namespace std;
vector<int>v[1000005];
bool g[1000005];
queue<int>q;
void dfs(int z){
	cout<<z<<" ";
	g[z]=1;
	for(int i=0;i<v[z].size();i++){
		if(!g[v[z][i]]){
			dfs(v[z][i]);
		}
	}
}
void bfs(){
	while(!q.empty() ){
		int x=q.front() ;
		q.pop() ;
		cout<<x<<" ";
		for(int i=0;i<v[x].size() ;i++){
			if(!g[v[x][i]]){
				q.push(v[x][i]);
				g[v[x][i]]=1;
			}
		}
	}
}
int main(){
	short int x,y;
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		cin>>x>>y;
		v[x].push_back(y);
	}
	for(int i=1;i<=n;i++){
		sort(v[i].begin(),v[i].end());
	}
	dfs(1);
	cout<<endl;
	memset(g,0,sizeof(g));
	q.push(1);
	g[1]=1;
	bfs();
}

回复

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

正在加载回复...