Guarding the Chessboard(UVA 11214)

网址如下:

Guarding the Chessboard - UVA 11214 - Virtual Judge

(第三方网址)

绞尽脑汁优化算法,结果暴力遍历就够了

孩子你无敌了

本质上是IDA

甚至不用剪枝

代码如下:

cpp 复制代码
#include<cstdio>
#include<algorithm>
#include<cstring>

const int maxn = 9;

bool G[maxn][maxn];
int vis[4][17];
int n, m;

bool succeed(void){
   for(int i = 0; i < n; i++)
      for(int j = 0; j < m; j++)
         if(G[i][j] && !vis[0][i] && !vis[1][j] && !vis[2][i + j] && !vis[3][i - j + 8])
            return false;
   return true;
}
bool dfs(int idx, int d, int maxd){
   if(succeed()) return true;
   if(d == maxd) return false;
   for(int cur = idx; cur < n * m; cur++){
      int i = cur / m, j = cur % m;
      vis[0][i]++; vis[1][j]++; vis[2][i + j]++; vis[3][i - j + 8]++;
      if(dfs(idx + 1, d + 1, maxd)) return true;
      vis[0][i]--; vis[1][j]--; vis[2][i + j]--; vis[3][i - j + 8]--;
   }
   return false;
}

int main(void)
{
   int kase = 0;
   while(scanf("%d", &n) && n){
      scanf("%d", &m); getchar();
      for(int i = 0; i < n; i++){
         for(int j = 0; j < m; j++)
            G[i][j] = getchar() == 'X';
         getchar();
      }
      for(int maxd = 1; maxd <= std::min(m, n); maxd++){
         memset(vis, 0, sizeof(vis));
         if(dfs(0, 0, maxd)){
            printf("Case %d: %d\n", ++kase, maxd);
            break;
         }
      }
   }

   return 0;
}
相关推荐
xiaoshiguang33 小时前
LeetCode:222.完全二叉树节点的数量
算法·leetcode
爱吃西瓜的小菜鸡3 小时前
【C语言】判断回文
c语言·学习·算法
别NULL3 小时前
机试题——疯长的草
数据结构·c++·算法
TT哇3 小时前
*【每日一题 提高题】[蓝桥杯 2022 国 A] 选素数
java·算法·蓝桥杯
yuanbenshidiaos4 小时前
C++----------函数的调用机制
java·c++·算法
唐叔在学习4 小时前
【唐叔学算法】第21天:超越比较-计数排序、桶排序与基数排序的Java实践及性能剖析
数据结构·算法·排序算法
ALISHENGYA4 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
chengooooooo5 小时前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
jackiendsc5 小时前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法
游是水里的游6 小时前
【算法day20】回溯:子集与全排列问题
算法