深度优先搜索例题(C语言)

本文介绍了一种使用C语言实现深度优先搜索(DFS)解决炸弹人问题的方法。通过DFS遍历地图,统计每个位置可以消灭的敌人数量,并提供了相应的代码实现。主要涉及的数据结构包括全局变量数组和二维数组,以及一个用于获取当前位置敌人数量的函数getnum()和深度优先搜索的dfs()函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇是对上一篇的炸弹人用了另一种解法
题目:
在这里插入图片描述
代码:

#include <stdio.h>
//全局变量
char a[21][21];
int book[20][21]={0},max,mx,my,n,m;//book数组的值为1表示已走过,为0表示未走过,初始化都为0;

//该函数用来统计每个点位可消灭的敌人数
int getnum(int i,int j)
{
int x,y,sum=0;
x=i;y=j;
while(a[x][y]!=’#’)//判断该点是否为墙
{
if (a[x][y]==‘G’)//判断该点是否有敌人,若有则进行统计
{
sum++;
}
//向上统计
x–;
}

x=i;y=j;
while(a[x][y]!='#')//判断该点是否为墙
{
	if (a[x][y]=='G')//判断该点是否有敌人,若有则进行统计
	{
		sum++;
	}
	//向下统计
	x++;
}

x=i;y=j;
while(a[x][y]!='#')//判断该点是否为墙
{
	if (a[x][y]=='G')//判断该点是否有敌人,若有则进行统计
	{
		sum++;
	}
	//向右统计
	y++;
}

x=i;y=j;
while(a[x][y]!='#')//判断该点是否为墙
{
	if (a[x][y]=='G')//判断该点是否有敌人,若有则进行统计
	{
		sum++;
	}
	//向左统计
	y--;
}

return sum;

}

void dfs(int x,int y)
{
int k,sum,tx,ty;
int next[4][2]={{0,1},{1,0},{0,-1},{-1,0}};//分别表示向右,下,左,上方向移动

sum=getnum(x,y);

//若(x,y)处可消灭的敌人数大于max,则更新max的值,保证max存放的是最大可消灭敌数
if (sum>max)
{
	max=sum;
	mx=x;
	my=y;
}

//枚举4个方向
for(k=0;k<=3;k++)
{
	tx=x+next[k][0];
	ty=y+next[k][1];

	//判断是否超出地图边界
	if (tx<0 || tx>n-1 || ty<0 ||ty>m-1)
	{
		continue;
	}

	//判断当前点位是否为空地,是否已经走过
	if (a[tx][ty]=='.' && book[tx][ty]==0)
	{
		book[tx][ty]=1;
		dfs(tx,ty);//以tx,ty为中心坐标,开始尝试下一个点
	}
}
return;//后退点位

}

int main()
{
int i,startx,starty;
//地图大小为n*m,初始点位为(startx,starty)
scanf("%d %d %d %d",&n,&m,&startx,&starty);

for (i=0;i<=n-1;i++)
{
	scanf("%s",a[i]);//一次读入一行
}
book[startx][starty]=1;
max=getnum(startx,starty);//给max附初值,不排除第一个点位可消灭的敌人数最大
mx=startx;my=starty;
dfs(startx,starty);
printf("将炸弹放置在(%d,%d),最多可以消灭%d个敌人\n",mx,my,max);	
return 0;

}

测试数据:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值