Uva572种子填充<dfs>



油田(Oil Deposits, UVa 572)
输入一个m行n列的字符矩阵,统计字符“@”组成多少个八连块。如果两个字符“@”所在
的格子相邻(横、竖或者对角线方向),就说它们属于同一个八连块。例如,图中有两
个八连块。

输入:

5 5
*  *  *  * @   
*@@ * @   
*@  * *  @
@@@*@
@@ * * @

注意题目的问题,看清题目先。

thinking:通过一个个字符判断,判断其是否为@,如果是,用dfs函数,然后给这个点打上一个标记,然后通过2个for循环将其周围的8个格子全部递归调用

dfs判断是否为@一遍,判断时先判断是否出界,然后判断是否没判断过且这个格子里的数为@,这样就可以将所有连着的@都打上标记,然后接着下次main的循环,

通过计算main的循环判断出最终的答案。

#include <stdio.h>
#include <string>
using namespace std;
char pic[10][10];
int dix[10][10];
int r,c;
void dfs(int i,int j,int f1){
	if(i<0||i>=r||j<0||j>=c)return;
	if(dix[i][j]!=0||pic[i][j]!='@')return;
	dix[i][j]=f1;
	for(int g=-1;g<=1;g++)
	 for(int h=-1;h<=1;h++)
	  if(g!=0||h!=0) dfs(i+g,j+h,f1);
}
int main(){
	int f1=0;
	freopen("in.txt","r",stdin);
	freopen("out.txt","w",stdout);
	while(scanf("%d%d",&r,&c)==2&&r&&c){
	 for(int i=0;i<r;i++)scanf("%s",pic[i]); 
	 	//将一整行都放入pic[0]中,因为其是二维数组,则pic[0][0]就为第一个字符
		 for(int i=0;i<r;i++)
		  for(int j=0;j<c;j++)
		  	if(pic[i][j]=='@'&&dix[i][j]==0) dfs(i,j,++f1);
 			printf("%d",f1); 
	}
} 


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值