8648 图的深度遍历
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector <int> e[100000]; //模拟邻接表
int book[100000];
void dfs(int cur)
{
cout<<(char)(cur+'a')<<' ';
int len=e[cur].size();
for(int i=0 ; i<len ; i++)
{
int y=e[cur][i];
if(book[y]==0)
{
book[y]=1;
dfs(y);
}
}
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
int t,n,m;
cin>>t>>n>>m;
for(int i=0 ; i<n ; i++) //cjb
{
char x;
cin>>x;
}
int st=0;
for(int i=0 ; i<m ; i++)
{
char x,y;
cin>>x>>y;
int a=x-'a';
int b=y-'a';
if(i==0)
st=a;
if(t<=1) //有向图
e[a].insert(e[a].begin(),b);
else //无向图
{
e[a].insert(e[a].begin(),b);
e[b].insert(e[b].begin(),a);
}
}
book[st]=1;
dfs(st);
return 1;
}
8649 图的广度遍历
#include <iostream>
#include <vector>
#include <algorithm>
#include <queue>
using namespace std;
vector <int> e[10000];
int book[10000];
queue <int> q;
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
int t,n,m;
cin>>t>>n>>m;
int st;
for(int i=0 ; i<n ; i++)
{
char x;cin>>x; //cjb
}
//建表
for(int i=0 ; i<m ; i++)
{
char x,y;
cin>>x>>y;
int a=x-'a'; /**注意此处*/
int b=y-'a'; /**注意此处*/
if(i==0)
st=a;
if(t<=1)
e[a].insert(e[a].begin(),b);
else
{
e[a].insert(e[a].begin(),b);
e[b].insert(e[b].begin(),a);
}
}
//建表完成
q.push(st);
book[st]=1;
while(!q.empty())
{
int t=q.front();
int len=e[t].size();
for(int i=0 ; i<len ; i++)
{
if(book[e[t][i]]==0)
{
q.push(e[t][i]);
book[e[t][i]]=1; /**注意:入队则是已访问*/
}
}
cout<<(char)(t+'a')<<' ';
q.pop();
}
return 0;
}