题意:输入一个n*m棋盘(n,m<10),某些格子有标记。用最少的皇后守卫(即占据或者攻击)所有带标记的格子。

分析:因为不知道放几个皇后可以守卫所有带标记的格子,即回溯法求解时解答树的深度没有明显的上限,所以使用迭代加深搜索。

将棋盘的每个格子标记为0~n*m-1,依次枚举守卫的皇后个数,枚举当前守卫的皇后个数下所有的放置情况,看是否能全部守卫。(枚举方式i:1~n,j:i+1~n……)

  1. #pragma comment(linker, "/STACK:102400000, 102400000")
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<cstdlib>
  5. #include<cctype>
  6. #include<cmath>
  7. #include<iostream>
  8. #include<sstream>
  9. #include<iterator>
  10. #include<algorithm>
  11. #include<string>
  12. #include<vector>
  13. #include<set>
  14. #include<map>
  15. #include<stack>
  16. #include<deque>
  17. #include<queue>
  18. #include<list>
  19. #define Min(a, b) ((a < b) ? a : b)
  20. #define Max(a, b) ((a < b) ? b : a)
  21. typedef long long ll;
  22. typedef unsigned long long llu;
  23. const int INT_INF = 0x3f3f3f3f;
  24. const int INT_M_INF = 0x7f7f7f7f;
  25. const ll LL_INF = 0x3f3f3f3f3f3f3f3f;
  26. const ll LL_M_INF = 0x7f7f7f7f7f7f7f7f;
  27. const int dr[] = {, , -, , -, -, , };
  28. const int dc[] = {-, , , , -, , -, };
  29. const int MOD = 1e9 + ;
  30. const double pi = acos(-1.0);
  31. const double eps = 1e-;
  32. const int MAXN = + ;
  33. const int MAXT = + ;
  34. using namespace std;
  35. char a[][];
  36. int vis[][];
  37. int mark[][];
  38. int kase;
  39. int n, m;
  40. bool judge(){
  41. for(int i = ; i < n; ++i){//判断所有被标记的正方形是否被保护
  42. for(int j = ; j < m; ++j){
  43. if(mark[i][j] && !vis[][i] && !vis[][j] && !vis[][j + i] && !vis[][j - i + n])
  44. return false;
  45. }
  46. }
  47. return true;
  48. }
  49. bool dfs(int cur, int pos, int tot){
  50. if(cur == tot){//放置tot个皇后是否可全保护
  51. if(judge()){
  52. printf("Case %d: %d\n", kase, tot);
  53. return true;
  54. }
  55. return false;
  56. }
  57. else{
  58. for(int i = pos; i < n * m; ++i){//所有点被标记成0~n*m-1
  59. int x = i / m;//当前位置的横坐标
  60. int y = i % m;
  61. int tmp1 = vis[][x];
  62. int tmp2 = vis[][y];
  63. int tmp3 = vis[][x + y];
  64. int tmp4 = vis[][y - x + n];
  65. vis[][x] = vis[][y] = vis[][x + y] = vis[][y - x + n] = ;
  66. if(dfs(cur + , i + , tot)) return true;//此处优化,i + 1下次枚举是当前位置再加1,避免情况重复
  67. vis[][x] = tmp1;
  68. vis[][y] = tmp2;
  69. vis[][x + y] = tmp3;
  70. vis[][y - x + n] = tmp4;
  71. }
  72. }
  73. return false;//枚举当前所有情况不满足
  74. }
  75. int main(){
  76. while(scanf("%d", &n) == ){
  77. if(!n) return ;
  78. ++kase;
  79. scanf("%d", &m);
  80. memset(a, , sizeof a);
  81. memset(mark, , sizeof mark);
  82. for(int i = ; i < n; ++i){
  83. scanf("%s", a[i]);
  84. }
  85. for(int i = ; i < n; ++i){
  86. for(int j = ; j < m; ++j){
  87. if(a[i][j] == 'X'){
  88. mark[i][j] = ;
  89. }
  90. }
  91. }
  92. for(int i = ; ; ++i){
  93. memset(vis, , sizeof vis);
  94. if(dfs(, , i)) break;
  95. }
  96. }
  97. return ;
  98. }

UVA - 11214 Guarding the Chessboard(守卫棋盘)(迭代加深搜索)的更多相关文章

  1. UVA 11214 Guarding the Chessboard 守卫棋盘(迭代加深+剪枝)

    暴力,和八皇后很像,用表示i+j和i-j标记主对角线,但是还是要加一些的剪枝的. 1.最裸的暴搜 6.420s,差点超时 2.之前位置放过的就没必要在放了,每次从上一次放的位置开始放 0.400s # ...

  2. UVA - 11214 Guarding the Chessboard(迭代加深搜索)

    题目: 输入一个n*m的棋盘(n,m<10),某些格子有标记,用最少的皇后守卫(即占据或攻击)所有的标记的格子.输出皇后的个数. 思路: 一开始没有想到用迭代加深搜索,直接dfs结果还没写完就发 ...

  3. UVA 11214 Guarding the Chessboard

    题意: 皇后防御的范围是他所在横.竖.对角线,地图上的#为可以放旗子的地方.问最少放几个皇后能防守所有#. 分析: vis数组开4维,对应行.列.主对角线.副对角线 代码: #include < ...

  4. UVA - 11214 Guarding the Chessboard (可重复覆盖,DLX+IDA*)

    题目链接 正解是IDA*+四个方向判重,但由于是个裸的可重复覆盖问题,可以用DLX水过~ 每个格子与放上皇后能干掉的标记连边,跑可重复覆盖DLX.注意要用IDA*来优化,否则会超时. #include ...

  5. UVA-11214 Guarding the Chessboard (迭代加深搜索)

    题目大意:在一个国际象棋盘上放置皇后,使得目标全部被占领,求最少的皇后个数. 题目分析:迭代加深搜索,否则超时. 小技巧:用vis[0][r].vis[1][c].vis[2][r+c].vis[c- ...

  6. UVA 529 - Addition Chains,迭代加深搜索+剪枝

    Description An addition chain for n is an integer sequence  with the following four properties: a0 = ...

  7. UVA 10160 Servicing Stations(状态压缩+迭代加深)

    [题目链接] LInk [题目大意] 给出一些点和边,选择一个点就能把这个点和相邻的点都覆盖,求最小点覆盖 [题解] 我们压缩点被覆盖的状态,迭代加深搜索覆盖的最小点数, 当剩余的点全部选上时都无法完 ...

  8. Power Calculus UVA - 1374 迭代加深搜索

    迭代加深搜索经典题目,好久不做迭代加深搜索题目,拿来复习了,我们直接对当前深度进行搜索,注意剪枝,还有数组要适当开大,因为2^maxd可能很大 题目:题目链接 AC代码: #include <i ...

  9. uva 11212 - Editing a Book(迭代加深搜索 IDA*) 迭代加深搜索

    迭代加深搜索 自己看的时候第一遍更本就看不懂..是非常水,但智商捉急也是没有办法的事情. 好在有几个同学已经是做过了这道题而且对迭代加深搜索的思路有了一定的了解,所以在某些不理解的地方询问了一下他们的 ...

随机推荐

  1. zookeeper logs is missing zookeeper 日志丢失

    ERROR [main:QuorumPeerMain@85] - Invalid config, exiting abnormally Invalid config, exiting abnormal ...

  2. Bootstrap入门(一)准备

    Bootstrap入门(一)准备         网页的样式化与布局展示是很多开发者要面对的问题,目前有多的框架和工具包,可以使网页设计的任务变得更加简单.轻松.方便.快捷一些,其中,bootstra ...

  3. IDEA中如何部署tomcat

    1.添加tomcat 2.添加tomcat所依赖的war包 test009.war包刚开始可能不存在,这个时候需要将maven项目进行打包,然后点击“+”之后就会出现一个和项目名同名的war包,选中就 ...

  4. 「HNOI/AHOI2018」道路

    传送门 Luogu 解题思路 考虑树形 \(\text{DP}\) 设状态 \(dp[u][i][j]\) 表示从首都走到点 \(u\) ,经过 \(i\) 条公路,\(j\) 条铁路的最小不方便值. ...

  5. vmware fusion 进入 BIOS

    要进入bios有三种方法:1.>启动的时候按F2即可进入bios进行一些启动盘等选项的操作.但是,启动的时候很难第一时间按F2成功进入bios, 2.>修改vmware 进入bios之前的 ...

  6. 十一 JSP&EL&JSTL

    1 什么是JSP? 从用户角度看待,是一个网页从程序员角度,其实是一个Java类,他继承了Servlet,所以可以直接说JSP就是一个Servlet 为什么会有JSP?html多数情况下用来显示静态内 ...

  7. MySQL存储过程例子

    -- 索引 INDEXCREATE INDEX idx_sname ON student( sname(4)); ALTER TABLE teacher add index idx_tname(tna ...

  8. NFC性价比高频读卡器首选方案:FM17550

    FM17550具有低电压.低功耗.驱动能力强.多接口支持.多协议支持等特点.适用于低功耗.低电压.低成本要求的非接触读写器应用,及NFC协议兼容的NFC设备. FM17550是一款高度集成的工作在13 ...

  9. uni app中关于图片的分包加载

    因为在项目中使用了大量的静态资源图片,使得主包体积过大, 而把这些图片全部放到服务器又有点麻烦,就想能不能把图片也分包,但是直接放在分包下的话导致图片资源找不到了, 在社区中看到大佬分享的十分有用,特 ...

  10. dubbo 相关面试题 有用(转)

    调用关系说明: · 0. 服务容器负责启动,加载,运行服务提供者. · 1. 服务提供者在启动时,向注册中心注册自己提供的服务. · 2. 服务消费者在启动时,向注册中心订阅自己所需的服务. · 3. ...