深搜与广搜

#include
#include
#include
#include
#include
using namespace std;

int mp[20][20], n, e,vis[20];

/*

cin>>n>>e;
while(e--)
{
	int a,b;
	cin>>a>>b;
	mp[a][b]=mp[b][a]=1;
}
memset(vis,0,sizeof(vis));

mp数组全部为1,而vis数组全为0;
mp数组用来指“路”,而vis数组用来指“点”

*/

//深搜
void DFS(int x)
{
vis[x] = 1;
cout << " " << x;
for(int i=0;i<n;i++)
{
if (mp[x][i] && !vis[i])
{
DFS(i);
}
}
}
/*
对深搜的理解
当搜索到该点时,改变该点的vis,为下一次可能来做警示。
然后以该点为起点(x),变动终点(i)看是否能连通。
如果连通(mp[x][i])同时查看该点没有被访问过(!vis[i])
如果这两个条件同时成立即可使用i作为下一个深搜的起点。
*/

void DFScout()
{
for (int i = 0; i < n; i++)
{
if (!vis[i])
{
cout << “{”;
DFS(i);
cout << " }" << endl;
}
}

}

//广搜

void BFS(int x)
{
queueque;
vis[x] = 1;
que.push(x);
while (!que.empty())
{
int yy = que.front();
cout << " " << yy;
que.pop();
for (int i = 0; i < n; i++)
{
if (!vis[i] && mp[yy][i])
{
que.push(i);
vis[i] = 1;
}
}
}
}

//对广搜的理解
/*
借助于queue队列,将起点(x)存储,然后以起点为原点,
将所有与原点连通的点都标记,然后每次标记一个点,
就见该点存入队列,作为下次的原点。以此来达到广搜的效果。
*/

void BFScout()
{
for (int i = 0; i < n; i++)
{
if (!vis[i])
{
cout << “{”;
BFS(i);
cout << " }" << endl;
}
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值