转载请注明出处:https://blog.csdn.net/Mercury_Lc/article/details/82684942作者:Mercury_Lc

题目链接

题解:dfs入门,就是每个点都搜索一下,什么时候够了k个就ans++。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <map>
#include <vector>
using namespace std; int n,k;
int ans = 0;
int step = 0;
char mp[55][55];
bool vis[55]; void dfs(int x)
{
int i;
if(step == k)
{
ans ++;
return ;
}
if(x >= n)
return ;
for(i = 0; i < n; i ++)
{
if(!vis[i] && mp[x][i] == '#')
{
step ++;
vis[i] = true;
dfs(x + 1);
vis[i] = false;
step --;
}
}
dfs(x + 1);
}
int main()
{
while(~scanf("%d%d",&n,&k))
{
if(n == -1 && k == -1)
return 0;
for(int i = 0; i < n; i ++)
{
getchar();
scanf("%s",&mp[i]);
}
ans = 0;
step = 0;
memset(vis,0,sizeof(vis));
dfs(0);
printf("%d\n",ans);
}
return 0;
}

problem

在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别。要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放方案C。

Input

输入含有多组测试数据。

每组数据的第一行是两个正整数,n k,用一个空格隔开,表示了将在一个n*n的矩阵内描述棋盘,以及摆放棋子的数目。 n <= 8 , k <= n

当为-1 -1时表示输入结束。

随后的n行描述了棋盘的形状:每行有n个字符,其中 # 表示棋盘区域, . 表示空白区域(数据保证不出现多余的空白行或者空白列)。

Output

对于每一组数据,给出一行输出,输出摆放的方案数目C (数据保证C<2^31)。

Sample Input

2 1

#.

.#

4 4

...#

..#.

.#..

#...

-1 -1

Sample Output

2

1

最新文章

  1. sql
  2. 【DP】HDU 1176
  3. 如何解决xx列不在表中
  4. centos6.8部署vnc服务
  5. flex 加载arcgis 的地图json
  6. Vusual C++连接Mysql和从MySql中取出数据的API介绍
  7. 【转】Mac 上 java 究竟在哪里,本文彻底让你搞清楚!
  8. [原创] CSS总结!! 有关HTML第二篇 !!
  9. SQL 各种连接:内连接,外连接(左外,右外,完全外)
  10. 如何用python语句获得Python的安装目录
  11. iOS 多线程学习笔记 —— NSThread
  12. 使用 HT 单片机芯片做触摸按键的试验:触摸按键实践一
  13. jquery节点查询
  14. jQuery ajax() 参数,回调函数,数据类型,发送数据到服务器,高级选项
  15. 看漫画学Flux
  16. 03_SQL server数据类型
  17. 在线播放Video/PDF/JPG
  18. ArcGIS案例学习笔记-CAD数据自动拓扑检查
  19. 六 json&amp;pickle模块
  20. unigui作中间件使用

热门文章

  1. go get 安装一个特定版本的包失败解决方法
  2. spring-cloud 学习二 服务发现
  3. java——多线程知识点大总结
  4. 修改NPM默认全局安装路径
  5. vue入门:(class与style绑定)
  6. 学习javascript,您将发现以下两个学习指南
  7. jstl中c:foreach下的表格实现异步刷新
  8. Swift调用微信支付宝SDK(Swift4.0)
  9. JLINK驱动版本更换
  10. “美登杯”上海市高校大学生程序设计邀请赛 **D. 小花梨的取石子游戏**