A - Fire Net(dfs)

参考:https://blog.csdn.net/weixin_41075012/article/details/79690951

思路:
1.找到要放的位置(x,y) 从x=0,y=(0,1,2,3) x=1,y=(1,2,3,4)……

int x = k/n ;
int y = k%n ;

dfs(k+1,num) ; 

2.深搜,到了最后一格(k=n*n)可以就return

if(k == n*n)

3.返回撤销,继续搜

a[x][y] = 'O' ;
dfs(k+1,num+1) ;
a[x][y] = '.' ;

总结:
1.输入图时,换行要getchar()
2.k的妙用(思路的1、2点)
3.dfs的方法:每题选坐标的方法不一样
上下左右走的 可以用xx[],yy[],vis[]数组实现。
这题的个人实现方法是一行一行找。

#include<iostream>
using namespace std ;
int n , cnt ;
char a[6][6] ;
int hang[6], lie[6] ;
int judge(int x,int y)
{
	for(int i = y-1 ; i >= 0 ; i--)//判断一行有没有遇到碉堡 ,向前找 
	{
		if(a[x][i] == 'X') break ;//遇到碉堡之前有墙壁,可 
		if(a[x][i] == 'O') return 0 ;//有碉堡,不可 
	}
	
	for(int i = x-1 ; i >= 0 ; i-- )//判断一列有没有遇到碉堡 ,向后找  
	{
		if(a[i][y] == 'X') break ;
		if(a[i][y] == 'O') return 0 ;
	}
	return 1 ;
}

void dfs(int k,int num)
{
	if(k == n*n)
	{
		cnt = max(num,cnt) ;
		printf("cnt = %d\n",cnt) ;
		return;
	}
	else
	{
		int x = k/n ;
		int y = k%n ;
		printf("x=%d y=%d\n",x,y) ;
		//printf("judge=%d\n",judge(x,y)) ;
		if(a[x][y] == '.' && judge(x,y))//可放置 
		{
			a[x][y] = 'O' ;
			printf("a[%d][%d]='O'\n",x,y) ;
			dfs(k+1,num+1) ;
			a[x][y] = '.' ;
			printf("a[%d][%d]='.'\n",x,y) ;
		}
		//不可放置
		dfs(k+1,num) ; 
	}
	return ;
}
int main()
{
	while(~scanf("%d",&n),n)
	{
		char ch ;
		for(int i = 0 ; i < n ; i++)
		{
			getchar() ;
			for(int j = 0 ; j < n ; j++) 
			{
				scanf("%c",&a[i][j]) ;
			}
		}
		cnt = 0 ;
		dfs(0,0) ;
		printf("%d\n",cnt) ;
	}
	return 0 ;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值