您的位置:首页 > 其它

棋盘问题 poj1321

2015-05-10 14:19 239 查看
<pre name="code" class="html">#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
#include <stack>
#include <queue>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
bool chess[10][10];
bool visit_col[10];
int status=0;
int k,n;

void BFS(int row,int num)
{
if(num==k)
{
status++;
return ;
}
if(row>n) return ;
for(int i=1;i<=n;i++)
if(chess[row][i]&&!visit_col[i])
{
visit_col[i]=true;
BFS(row+1,num+1);
visit_col[i]=false;
}
BFS(row+1,num);
return ;
}

int main()
{
while(~scanf("%d%d",&n,&k))
{
status=0;
if(n==-1&&k==-1) break;
memset(chess,false,sizeof(chess));
memset(visit_col,false,sizeof(visit_col));
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
char c;
cin>>c;
if(c=='#') chess[i][j]=true;
}
BFS(1,0);
printf("%d\n",status);
}
return 0;
}



                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: