poj1321
来源:互联网 发布:时间煮雨 歌词 知乎 编辑:程序博客网 时间:2024/05/11 00:28
#include<iostream>
#include<string>
using namespace std;
string ss[9];
int f[9];//标记第i行是否放过棋子
int n,k,num;
void dfs(int r,int p){
if(p==0) {num++; return;}
if(r==n) return;
for(int j=0;j<n;j++){
if(!f[j]&&ss[r][j]=='#'){
f[j]=1;
dfs(r+1,p-1);
f[j]=0;}
}
dfs(r+1,p);//不好理解!由于上面的if语句保证从第一行和从第0开始放的情况不会重复!
}
int main(){
while(cin>>n>>k){
if(n==-1&&k==-1) break;
num=0;
for(int i=0;i<n;i++) cin>>ss[i];
memset(f,0,sizeof(f));
dfs(0,k);//0代表从第0行开始;
cout<<num<<endl;}
return 0;}
- poj1321
- POJ1321
- poj1321
- poj1321
- poj1321
- POJ1321
- POJ1321
- poj1321
- poj1321
- POJ1321
- poj1321
- poj1321
- poj1321
- poj1321
- POJ1321
- poj1321
- poj1321
- poj1321
- joj2661
- SQL2008的数据更新跟踪测试
- 求n个数选m个数的组合数
- 关于SQL语句Count的一点细节
- win7 安装Memcache
- poj1321
- java编程思想
- joj1039
- Linux终端
- hdoj2037
- poj2376
- 超级皮波的9个马甲,因扎吉生日快乐!
- c#sqlcommand 使用方法
- memcache 研究