参考: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 ;
}