POJ 1321:棋盘问题
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 21666 | Accepted: 10765 |
Description
Input
每组数据的第一行是两个正整数,n k。用一个空格隔开,表示了将在一个n*n的矩阵内描写叙述棋盘,以及摆放棋子的数目。 n <= 8 , k <= n
当为-1 -1时表示输入结束。
随后的n行描写叙述了棋盘的形状:每行有n个字符。当中 # 表示棋盘区域。 . 表示空白区域(数据保证不出现多余的空白行或者空白列)。
Output
Sample Input
2 1
#.
.#
4 4
...#
..#.
.#..
#...
-1 -1
Sample Output
2
1
深搜。
注意k<n的处理。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream> using namespace std; int n , k;
int chess[10][10];
int vist[10];
int ans; void dfs(int x, int num)
{
if(num==k)
{
ans++;
return ;
}
if(x>n)
return ;
for(int i=1; i<=n; i++)
{
if(chess[x][i]==1 && vist[i]==0)
{
vist[i]=1;
dfs(x+1, num+1);
vist[i]=0; //回溯后还原数据
}
}
dfs(x+1, num);
} int main()
{
char str;
while(scanf("%d%d", &n, &k)!=EOF)
{
memset(chess, 0, sizeof(chess));
memset(vist, 0, sizeof(vist));
ans=0;
if(n==-1 && k==-1)
break;
for(int i=1; i<=n; i++)
for(int j=1; j<=n; j++)
{
cin>>str;
if(str=='#')
chess[i][j]=1;
}
dfs(1, 0);
cout<<ans<<endl;
} return 0;
}
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream> using namespace std; #define max 100 char map[max][max];
int s[max];
int n,k,i,j,a; void dfs(int x,int y) //函数參量表示的意思:x表示该棋盘的第x行,y表示放置第y个棋子
{
int i,j;
if(y==k) // 递归边界
a++;
else
{
for(i=x+1;i<=n;i++) // 按行讨论
{
for(j=1;j<=n;j++) // 从1 到 n列
{
if( map[i][j]=='#' && !s[j] ) // 若该点是 '#'且该点的这一列没有旗子。则能够在该位置放棋子。 {
s[j]=1;
dfs(i,y+1);
s[j]=0;
}
}
}
}
} int main ()
{ while (~scanf("%d%d",&n,&k)&&n!=-1&&k!=-1)
{
a=0;
memset(s,0,sizeof(s));
getchar(); //
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
scanf("%c",&map[i][j]);
getchar(); //
}
dfs(0,0);
printf("%d\n",a);
}
return 0;
}
POJ 1321:棋盘问题的更多相关文章
- POJ 1321 棋盘问题 --- DFS
POJ 1321 题目大意:给定一棋盘,在其棋盘区域放置棋子,需保证每行每列都只有一颗棋子. (注意 .不可放 #可放) 解题思路:利用DFS,从第一行开始依次往下遍历,列是否已经放置棋子用一个数组标 ...
- DFS POJ 1321 棋盘问题
题目传送门 /* DFS:因为一行或一列都只放一个,可以枚举从哪一行开始放,DFS放棋子,同一列只能有一个 */ #include <cstdio> #include <algori ...
- POJ 1321 棋盘问题(C)回溯
Emmm,我又来 POJ 了,这题感觉比上次做的简单点.类似皇后问题.但是稍微做了一点变形,比如棋子数量是不定的.棋盘形状不在是方形等等. 题目链接:POJ 1321 棋盘问题 解题思路 基本思路:从 ...
- OpenJudge/Poj 1321 棋盘问题
1.链接地址: http://bailian.openjudge.cn/practice/1321 http://poj.org/problem?id=1321 2.题目: 棋盘问题 Time Lim ...
- POJ 1321 棋盘问题(DFS板子题,简单搜索练习)
棋盘问题 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44012 Accepted: 21375 Descriptio ...
- POJ 1321 - 棋盘问题 - [经典DFS]
题目链接:http://poj.org/problem?id=1321 Time Limit: 1000MS Memory Limit: 10000K Description 在一个给定形状的棋盘(形 ...
- poj 1321 棋盘问题 递归运算
棋盘问题 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 19935 Accepted: 9933 Description ...
- poj 1321 棋盘问题 简单DFS
题目链接:http://poj.org/problem?id=1321 很久没有敲搜索了啊,今天敲了个水题练练手,哈哈.... 题目大意: 就是求在n*n的方格上放置k个棋子的方案数 代码: #inc ...
- POJ 1321 棋盘问题(状态压缩DP)
不总结的话, 同一个地方会 WA 到死 思路: 状态压缩 DP. 1. s 表示压缩状态, 若第 i 列放了棋子, 那么该列置 1, 否则该列置 0. 假如 s = 3(0x011) 那么表示棋盘的第 ...
- POJ 1321 棋盘问题 dfs 难度:0
http://poj.org/problem?id=1321 注意是在'#'的地方放棋子 矩阵大小不过8*8,即使是8!的时间复杂度也足以承受,可以直接dfs求解 dfs时标注当前点的行和列已被访问, ...
随机推荐
- Java隐藏手机号中间四位,隐藏身份证中间数字
原文:https://blog.csdn.net/yuanquanl/article/details/53519577 public static void main(String[] args) { ...
- 【spring boot】启动类启动 错误: 找不到或无法加载主类 com.codingapi.tm.TxManagerApplication 的解决方案
导入的一个外部的spring boot项目,运行启动类,出现错误:找不到或无法加载主类 com.codingapi.tm.TxManagerApplication 解决方案: 将所有错误处理完成后,再 ...
- .NET:用T4消除代码重复,对了,也错了
背景 我需要为int.long.float等这些数值类型写一些扩展方法,但是我发现他们不是一个继承体系,我的第一个思维就是需要为每个类型重复写一遍扩展方法,这让我觉得非常不爽,但是我还是不情愿的写了, ...
- Visual Studio 2012连接TFS2010登录不了
一直用VS2012+TFS2010开发项目, 最近几天忽然很不正常, 在VS中会频繁要求输入TFS的账号密码, 经常要输入很多遍才可以正常连接签入签出. 这几天更甚, 基本上直接连接不了了. 网上找到 ...
- Spark1.0.0 应用程序部署工具spark-submit
原文链接:http://blog.csdn.net/book_mmicky/article/details/25714545 随着Spark的应用越来越广泛,对支持多资源管理器应用程序部署工具的需求也 ...
- add-strings
https://leetcode.com/problems/add-strings/ package com.company; import java.util.LinkedList; import ...
- go语言基础之普通参数列表
1.普通参数列表 (备注:只有一个参数) 示例1: package main //必须有一个main包 import "fmt" //有参无返回值函数的定义,普通参数列表 //定义 ...
- idea maven 报-source 1.5 中不支持 diamond 运算符
需要修改 project setting 中的
- vi命令整理
vi命令整理 u 撤销上一次操作 ctrl+r 恢复上一次操作 : 跳转至第1行 :$ 跳转至最后一行 ctrl+f 向文章末尾翻页 ctrl+b 向文章开始翻页 yy 复制一行 p 粘贴刚刚复制第一 ...
- ireport制作报表pageheader只在第一页出现的解决办法
这问题居然没找到解决办法..... 好吧,那我自己解决..... 其实很简单..... 只要打开ireport,pageheader的属性,在print when expression设置$V{PAG ...