POJ1321棋盘问题
http://poj.org/problem?id=1321
题意 : 我能说这是迄今为止见到的POJ上第二道中文题吗,既然是中文也很好理解,就不详述了
思路 : 典型的深搜DFS ;
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std ;
const int maxn = ;
int vis[maxn] ;
int ch[maxn][maxn] ;
int cnt = ,n,k ;
int judge(int a,int b)//判断这个棋子的这一行和这一列是否还有别的可以放棋子的地方
{
for(int i = ; i <= n ; i++)
{
if(ch[a][i] == -)
return ;
if(ch[i][b] == -)
return ;
}
return ;
}
void dfs(int step,int col)//step代表的是步数,col代表着是放了棋子的个数
{
if(col == k)
{
cnt++ ;
return ;
}
if(step == n*n)
return ;
int a = step/n+ ;//现在棋子所在位置的行和列
int b = step%n+ ;
if(ch[a][b]&&judge(a,b))//这个点是#号并且这个点所在的行和列没有别的#了
{
ch[a][b] = - ;//代表着#这个点已经放上了
dfs(step+,col+) ;
ch[a][b] = ;//表示那一种已经操作完毕,恢复原样,找下一种方法
}
dfs(step+,col) ;//因为放法有很多种,所以可以本来的这里不放放下一个
return ;
}
int main()
{
while(~scanf("%d %d",&n,&k))
{
if(n == -&&k == -)
break ;
cnt = ;
char sh ;
memset(ch,,sizeof(ch)) ;
for(int i = ; i <= n ; i++)
{
for(int j = ; j <= n ; j ++)
{
cin>>sh ;
if(sh == '#')
ch[i][j] = ;//#标记为1代表是可以放棋子的
}
}
dfs(,) ;
cout<<cnt<<endl ;
}
}
这是小优姐写的,简洁明了、
//Memory Time
//184K 32MS #include<iostream>
using namespace std; bool chess[][];
bool vist_col[]; //列标记
int status; //状态计数器
int n,k; void DFS(int row,int num) //逐行搜索,row为当前搜索行,num为已填充的棋子数
{
if(num==k)
{
status++;
return;
} if(row>n) //配合下面DFS(row+1,num); 语句使用,避免搜索越界
return; for(int j=;j<=n;j++)
if(chess[row][j] && !vist_col[j])
{
vist_col[j]=true; //放置棋子的列标记
DFS(row+,num+);
vist_col[j]=false; //回溯后,说明摆好棋子的状态已记录,当前的列标记还原
} DFS(row+,num); //这里是难点,当k<n时,row在等于n之前就可能已经把全部棋子放好
//又由于当全部棋子都放好后的某个棋盘状态已经在前面循环时记录了
//因此为了处理多余行,令当前位置先不放棋子,搜索在下一行放棋子的情况
return;
} int main(int i,int j)
{
while(cin>>n>>k)
{
if(n==- && k==-)
break; /*Initial*/ memset(chess,false,sizeof(chess));
memset(vist_col,false,sizeof(vist_col));
status=; for(i=;i<=n;i++)
for(j=;j<=n;j++)
{
char temp;
cin>>temp;
if(temp=='#')
chess[i][j]=true;
} DFS(,); //注意初始化的值别弄错了
cout<<status<<endl;
}
return ;
}
POJ1321棋盘问题的更多相关文章
- poj1321 棋盘问题(DFS)
题目链接 http://poj.org/problem?id=1321 题意 给定一块棋盘(棋盘可能是不规则的),有k个相同棋子,将k个棋子摆放在棋盘上,使得任意两个棋子不同行,不同列,求有多少种不同 ...
- POJ1321 棋盘问题(简单搜索)
题意: 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放 ...
- POJ-1321.棋盘问题.(回溯)
做完题之后看了网上的一些题解但是发现他们的解释大部分都是错误的,所以就自己写了一下,笔者能力也有限,有错误之处大家多多指正. 第一次看题的时候以为就是简单的八皇后,但是写了之后发现存在很多问题,比如需 ...
- poj1321 棋盘问题(深搜dfs)
转载请注明出处:http://blog.csdn.net/u012860063? viewmode=contents 题目链接:id=1321">http://poj.org/prob ...
- 解题报告:poj1321 棋盘问题 - 搜索
棋盘问题 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 51262 Accepted: 24785 Description 在一 ...
- DFS(3)——poj1321棋盘问题
一.题目回顾 题目链接:棋盘问题 Description 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于 ...
- POJ1321 棋盘问题 —— DFS回溯
题目链接:http://poj.org/problem?id=1321 棋盘问题 Time Limit: 1000MS Memory Limit: 10000K Total Submissions ...
- poj1321棋盘问题(dfs+摆放问题)
在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放方案C. ...
- POJ1321棋盘问题(暴搜)
在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放方案C. ...
随机推荐
- Linux下编译安装mysql-5.0.45.tar.gz
安装环境:VMware9(桥接模式) + Linux bogon 2.6.32-642.3.1.el6.x86_64(查看linux版本信息:uname -a) 先给出MySQL For Linux ...
- CentOS学习笔记--基本命令--目录的相关操作
Linux基本命令--目录的相关操作 常见的处理目录的命令吧: cd:变换目录 pwd:显示目前的目录 mkdir:创建一个新的目录 rmdir:删除一个空的目录 cd (变换目录) cd是Chang ...
- 局域网实现 yum
1 安装squid代理 ##### . 安装squid yum -y remove squid yum -y install squid ##### . 修改配置文件 vi /etc/squid/sq ...
- [react native] Error loading page
如上图显示的错误,解决方法如下: 在react native ios项目的info.plist文件中,新增一个属性. 在Info.plist中添加NSAppTransportSecurity类型Dic ...
- 重拾C,一天一点点_5
switch(表达式){ case 整型常量表达式:语句序列 case 整型常量表达式:语句序列 default:语句序列} while(表达式) 语句 for(表达式1; 表 ...
- 【PHP】phpcms 关联连接修复
function _keylinks($txt, $replacenum = '',$link_mode = 1) { $keywords = $this->data['keywords']; ...
- PHP:strpos()-返回字符串在另一个字符串中第一次出现的位置
strpos()函数返回字符串在另一个字符串中第一次出现的位置.如果没有找到该字符串,则返回false. 语法:strpos(sting, find [, start]) string ,必须,要搜索 ...
- 如果在配置中将“system.serviceModel/serviceHostingEnvironment/multipleSiteBindingsEnabled”设置为 true,则需要终结点指定相对地址。如果在终结点上指定相对侦听 URI,则该地址可以是绝对地址。若要解决此问题,请为终结点“http://localhost/Service1.svc”指定相对 URI。
问题: 如果在配置中将"system.serviceModel/serviceHostingEnvironment/multipleSiteBindingsEnabled"设置为 ...
- SQLserver关于教学楼中教室在某个时间段是否被占用的数据库设计
需求:关于教学楼中教室在周几某个时间段是否被占用的数据库设计 具体代码如下: -------------------教学楼维度 CREATE TABLE TeacBuild ( tbID int no ...
- margin-top相对谁的问题
根据规范,一个盒子如果没有上补白(padding-top)和上边框(border-top),那么这个盒子的上边距会和其内部文档流中的第一个子元素的上边距重叠.意思便是:如果你只想margin相对于父标 ...