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棋盘问题的更多相关文章

  1. poj1321 棋盘问题(DFS)

    题目链接 http://poj.org/problem?id=1321 题意 给定一块棋盘(棋盘可能是不规则的),有k个相同棋子,将k个棋子摆放在棋盘上,使得任意两个棋子不同行,不同列,求有多少种不同 ...

  2. POJ1321 棋盘问题(简单搜索)

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

  3. POJ-1321.棋盘问题.(回溯)

    做完题之后看了网上的一些题解但是发现他们的解释大部分都是错误的,所以就自己写了一下,笔者能力也有限,有错误之处大家多多指正. 第一次看题的时候以为就是简单的八皇后,但是写了之后发现存在很多问题,比如需 ...

  4. poj1321 棋盘问题(深搜dfs)

    转载请注明出处:http://blog.csdn.net/u012860063? viewmode=contents 题目链接:id=1321">http://poj.org/prob ...

  5. 解题报告:poj1321 棋盘问题 - 搜索

    棋盘问题 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 51262 Accepted: 24785 Description 在一 ...

  6. DFS(3)——poj1321棋盘问题

    一.题目回顾 题目链接:棋盘问题 Description 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于 ...

  7. POJ1321 棋盘问题 —— DFS回溯

    题目链接:http://poj.org/problem?id=1321 棋盘问题 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions ...

  8. poj1321棋盘问题(dfs+摆放问题)

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

  9. POJ1321棋盘问题(暴搜)

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

随机推荐

  1. 从基础知识到重写Spring的Bean工厂中学习java的工厂模式

    1.静态工厂模式其他对象不能直接通过new得到某个类,而是通过调用getInstance()方法得到该类的对象这样,就可以控制类的产生过程.顺带提一下单例模式和多例模式:  单例模式是指控制其他对象获 ...

  2. mysql数据库的简单操作

    首先进入mysql:mysql -u root -p 1.建库: create database 库名称; 例如:create database mydata;(创建一个名为“mydata”的库): ...

  3. 前端自动化构建工具——gulp

    gulp是基于流的前端自动化构建工具. 一.环境配置 gulp是基于nodejs的,所以没有 nodejs 环境的要先去安装好 然后给系统配上gulp环境 npm install -g gulp 再到 ...

  4. javascript 创建对象及对象原型链属性介绍

    我们知道javascript里定义一个普通对象的方法,如: let obj = {}; obj.num = 1; obj.string = 'string'; obj.func = function( ...

  5. 分享:perl 文件操作总结

    发布:thebaby 来源:net [大 中 小] perl 文件操作,包括打开.关闭文件,读取.定入文件等.原文链接:http://www.jbxue.com/article/3153.html 打 ...

  6. 为ProgressBar进度条设置颜色1

    可以通过xml文件来设置,方法如下: 1:先在布局文件中的ProgressBar加入下面属性: android:progressDrawable="@drawable/progress_ba ...

  7. js实现复制到剪切板

    // <![CDATA[ function copy_clip(copy) { if (window.clipboardData) { window.clipboardData.setData( ...

  8. 斐波那契(Fibonacci)数列的七种实现方法

    废话不多说,直接上代码 #include "stdio.h" #include "queue" #include "math.h" usin ...

  9. Nginx模块开发1_明白自定义模块的编译流程

    自定义模块的编译流程 --add-module参数 configure使用--add-module参数指定添加模块目录. config脚本 由--add-module指定的目录保存为$ngx-addo ...

  10. Scene (场景视图) 详解

    控制二维切换的按钮 点击2D按钮可以激活2D模式.这个按钮会将场景相机在透视视图和正交投影视图之间进行切换.当观察透视视图时,远离相机的物体看起来更小:然而,当正交投影视图的时候,物体的大小并不受相机 ...