大佬们,帮我看看为什么超内存(MLE)了
查看原帖
大佬们,帮我看看为什么超内存(MLE)了
299711
单调欧文楼主2020/12/9 13:34
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int n,m,b[100001];
vector<int> adj[100001]; 
void dfs(int u){
	for(int i=0;i<adj[u].size();i++){
		if(b[adj[u][i]]==0)cout<<adj[u][i]<<" ";
		dfs(adj[u][i]);
		b[adj[u][i]]=1;
	}
}
void bfs(int u){
	for(int i=0;i<adj[u].size();i++) {
		if(b[adj[u][i]]==0)cout<<adj[u][i]<<" ";
		b[adj[u][i]]=1;
	}
	for(int i=0;i<adj[u].size();i++) bfs(adj[u][i]);
}
int main(){
	cin>>n>>m;
	for(int i=0;i<m;i++){
		int vv,uu; 
		cin>>uu>>vv;
        adj[uu].push_back(vv);
	}
	for(int i=1;i<=n;i++){
	sort(adj[i].begin(),adj[i].end()); 
	}
	cout<<1<<" ";
	dfs(1);
	for(int i=1;i<=n;i++) b[i]=0;
	cout<<endl<<1<<" ";
	bfs(1);
	return 0;
} 
2020/12/9 13:34
加载中...