http://poj.org/problem?id=1321

题意 : 我能说这是迄今为止见到的POJ上第二道中文题吗,既然是中文也很好理解,就不详述了

思路 : 典型的深搜DFS ;

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<iostream>
  4. using namespace std ;
  5. const int maxn = ;
  6. int vis[maxn] ;
  7. int ch[maxn][maxn] ;
  8. int cnt = ,n,k ;
  9. int judge(int a,int b)//判断这个棋子的这一行和这一列是否还有别的可以放棋子的地方
  10. {
  11. for(int i = ; i <= n ; i++)
  12. {
  13. if(ch[a][i] == -)
  14. return ;
  15. if(ch[i][b] == -)
  16. return ;
  17. }
  18. return ;
  19. }
  20. void dfs(int step,int col)//step代表的是步数,col代表着是放了棋子的个数
  21. {
  22. if(col == k)
  23. {
  24. cnt++ ;
  25. return ;
  26. }
  27. if(step == n*n)
  28. return ;
  29. int a = step/n+ ;//现在棋子所在位置的行和列
  30. int b = step%n+ ;
  31. if(ch[a][b]&&judge(a,b))//这个点是#号并且这个点所在的行和列没有别的#了
  32. {
  33. ch[a][b] = - ;//代表着#这个点已经放上了
  34. dfs(step+,col+) ;
  35. ch[a][b] = ;//表示那一种已经操作完毕,恢复原样,找下一种方法
  36. }
  37. dfs(step+,col) ;//因为放法有很多种,所以可以本来的这里不放放下一个
  38. return ;
  39. }
  40. int main()
  41. {
  42. while(~scanf("%d %d",&n,&k))
  43. {
  44. if(n == -&&k == -)
  45. break ;
  46. cnt = ;
  47. char sh ;
  48. memset(ch,,sizeof(ch)) ;
  49. for(int i = ; i <= n ; i++)
  50. {
  51. for(int j = ; j <= n ; j ++)
  52. {
  53. cin>>sh ;
  54. if(sh == '#')
  55. ch[i][j] = ;//#标记为1代表是可以放棋子的
  56. }
  57. }
  58. dfs(,) ;
  59. cout<<cnt<<endl ;
  60. }
  61. }

这是小优姐写的,简洁明了、

  1. //Memory Time
  2. //184K 32MS
  3.  
  4. #include<iostream>
  5. using namespace std;
  6.  
  7. bool chess[][];
  8. bool vist_col[]; //列标记
  9. int status; //状态计数器
  10. int n,k;
  11.  
  12. void DFS(int row,int num) //逐行搜索,row为当前搜索行,num为已填充的棋子数
  13. {
  14. if(num==k)
  15. {
  16. status++;
  17. return;
  18. }
  19.  
  20. if(row>n) //配合下面DFS(row+1,num); 语句使用,避免搜索越界
  21. return;
  22.  
  23. for(int j=;j<=n;j++)
  24. if(chess[row][j] && !vist_col[j])
  25. {
  26. vist_col[j]=true; //放置棋子的列标记
  27. DFS(row+,num+);
  28. vist_col[j]=false; //回溯后,说明摆好棋子的状态已记录,当前的列标记还原
  29. }
  30.  
  31. DFS(row+,num); //这里是难点,当k<n时,row在等于n之前就可能已经把全部棋子放好
  32. //又由于当全部棋子都放好后的某个棋盘状态已经在前面循环时记录了
  33. //因此为了处理多余行,令当前位置先不放棋子,搜索在下一行放棋子的情况
  34. return;
  35. }
  36.  
  37. int main(int i,int j)
  38. {
  39. while(cin>>n>>k)
  40. {
  41. if(n==- && k==-)
  42. break;
  43.  
  44. /*Initial*/
  45.  
  46. memset(chess,false,sizeof(chess));
  47. memset(vist_col,false,sizeof(vist_col));
  48. status=;
  49.  
  50. for(i=;i<=n;i++)
  51. for(j=;j<=n;j++)
  52. {
  53. char temp;
  54. cin>>temp;
  55. if(temp=='#')
  56. chess[i][j]=true;
  57. }
  58.  
  59. DFS(,); //注意初始化的值别弄错了
  60. cout<<status<<endl;
  61. }
  62. return ;
  63. }

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. activiti系列导读

    此用于管理activiti系列标签文章,activiti的分析是建立在目前最新的版本5.21之上. 官方指导手册链接:http://www.activiti.org/userguide/index.h ...

  2. Logstash+kibana+ ElasticSearch+redis

    这是之前Logstash+kibana+ ElasticSearch+redis 安装时,自己整理的初学者容易看懂的资料,按照以下的步骤也已经完成了安装. 这里有二台服务器: 192.168.148. ...

  3. Objective-C中字典的使用方法总结

    在Objective-C中提供了两个类来实现字典,即NSDictionary和NSMutableDictionary.其中,NSMutableDictionary是NSDictionary的子类,它继 ...

  4. uniform 中checkbox通过jquery 选中

    你是否曾经为不能修改多选框.单选框.文件选择框的样式而郁闷呢,是否想过控制它们的样式且兼容所有浏览器呢?我现在给你推荐的这个jQuery表单美化插件Uniform就可以解决这些问题. Uniform可 ...

  5. Color About——First

    最近在Android开发学习中遇到TextView背景色以及文字颜色着色问题,在此做个记录. 首先对于颜色的选择,我推荐W3C School,上面有对网页颜色的详尽说明以及实例,还提供了对于,同一种颜 ...

  6. 机器学习实战——k-邻近算法:约会网站

    1.kNN 算法 算法说明: set<X1,X2……Xn> 为已知类别数据集,预测 点Xt 的类别: (1)计算中的set中每一个点与Xt的距离 (2)按距离增序排列 (3)选择距离最小的 ...

  7. 【转载】MySQL innodb_table_stats表不存在的解决方法

    MySQL 版本 5.6.14 公司有几台MySQL服务器的错误日志显示,有几个系统表不存在.innodb_table_statsinnodb_index_statsslave_master_info ...

  8. ASP.NET MVC +EasyUI 权限设计(三)基础模块

    请注明转载地址:http://www.cnblogs.com/arhat 在上一章中呢,我们基本上搭建好了环境,那么本章我们就从基础模块开始写起.由于用户,角色,动作三个当中,都是依赖与动作的,所以本 ...

  9. always语言指导原则

    1.每个always只有一个@(event-expression). 2.always块可以表示时序逻辑和组合逻辑. 3.带有posedge和negedge关键字的是表示沿触发的时序逻辑,没有的表示组 ...

  10. iTween基础之Audio(音量和音调的变化)

    一.基础介绍:二.基础属性 原文地址 : http://blog.csdn.net/dingkun520wy/article/details/50826033 一.基础介绍 AudioTo:改变声音的 ...