UVA-11214 Guarding the Chessboard (迭代加深搜索)
题目大意:在一个国际象棋盘上放置皇后,使得目标全部被占领,求最少的皇后个数。
题目分析:迭代加深搜索,否则超时。
小技巧:用vis[0][r]、vis[1][c]、vis[2][r+c]、vis[c-r+N]分别标志(r,c)位置相对应的行、列、主、副对角线有没有被占领(详见《入门经典(第2版)》P193),其中N表示任意一个比行数和列数都大(大于等于)的数。
代码如下:
# include<iostream>
# include<cstdio>
# include<cstring>
# include<algorithm>
using namespace std; char p[13][13];
int vis[4][30],n,m,ans; bool dfs(int cur,int maxd)
{
if(cur==maxd){
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
if(p[i][j]=='X'&&!vis[0][i]&&!vis[1][j]&&!vis[2][i+j]&&!vis[3][j-i+11])
return false;
return true;
}
for(int i=cur+1;i<=n;++i){
for(int j=1;j<=m;++j){
if(!vis[0][i]||!vis[1][j]||!vis[2][i+j]||!vis[3][j-i+11]){
int a=vis[0][i],b=vis[1][j],c=vis[2][i+j],d=vis[3][j-i+11];
vis[0][i]=vis[1][j]=vis[2][i+j]=vis[3][j-i+11]=1;
if(dfs(cur+1,maxd))
return true;
vis[0][i]=a,vis[1][j]=b,vis[2][i+j]=c,vis[3][j-i+11]=d;
}
}
}
return false;
}
int main()
{
int cas=0;
while(scanf("%d",&n)&&n)
{
scanf("%d",&m);
for(int i=1;i<=n;++i)
scanf("%s",p[i]+1);
int ans;
for(ans=1;;++ans){
memset(vis,0,sizeof(vis));
if(dfs(0,ans))
break;
}
printf("Case %d: %d\n",++cas,ans);
}
return 0;
}
UVA-11214 Guarding the Chessboard (迭代加深搜索)的更多相关文章
- UVA - 11214  Guarding the Chessboard(迭代加深搜索)
		
题目: 输入一个n*m的棋盘(n,m<10),某些格子有标记,用最少的皇后守卫(即占据或攻击)所有的标记的格子.输出皇后的个数. 思路: 一开始没有想到用迭代加深搜索,直接dfs结果还没写完就发 ...
 - UVA - 11214 Guarding the Chessboard(守卫棋盘)(迭代加深搜索)
		
题意:输入一个n*m棋盘(n,m<10),某些格子有标记.用最少的皇后守卫(即占据或者攻击)所有带标记的格子. 分析:因为不知道放几个皇后可以守卫所有带标记的格子,即回溯法求解时解答树的深度没有 ...
 - UVA 529 - Addition Chains,迭代加深搜索+剪枝
		
Description An addition chain for n is an integer sequence with the following four properties: a0 = ...
 - uva 11212 - Editing a Book(迭代加深搜索 IDA*) 迭代加深搜索
		
迭代加深搜索 自己看的时候第一遍更本就看不懂..是非常水,但智商捉急也是没有办法的事情. 好在有几个同学已经是做过了这道题而且对迭代加深搜索的思路有了一定的了解,所以在某些不理解的地方询问了一下他们的 ...
 - UVA 1343 - The Rotation Game-[IDA*迭代加深搜索]
		
解题思路: 这是紫书上的一道题,一开始笔者按照书上的思路采用状态空间搜索,想了很多办法优化可是仍然超时,时间消耗大的原因是主要是: 1)状态转移代价很大,一次需要向八个方向寻找: 2)哈希表更新频繁: ...
 - UVA 11212 Editing a Book [迭代加深搜索IDA*]
		
11212 Editing a Book You have n equal-length paragraphs numbered 1 to n. Now you want to arrange the ...
 - UVA 11214	Guarding the Chessboard 守卫棋盘(迭代加深+剪枝)
		
暴力,和八皇后很像,用表示i+j和i-j标记主对角线,但是还是要加一些的剪枝的. 1.最裸的暴搜 6.420s,差点超时 2.之前位置放过的就没必要在放了,每次从上一次放的位置开始放 0.400s # ...
 - UVA - 1374  Power Calculus (dfs迭代加深搜索)
		
题目: 输入正整数n(1≤n≤1000),问最少需要几次乘除法可以从x得到xn ?在计算过程中x的指数应当总是正整数. 思路: dfs枚举次数深搜 注意: 1.指数如果小于0,就退出当前的搜索 2.n ...
 - UVA 11214 Guarding the Chessboard
		
题意: 皇后防御的范围是他所在横.竖.对角线,地图上的#为可以放旗子的地方.问最少放几个皇后能防守所有#. 分析: vis数组开4维,对应行.列.主对角线.副对角线 代码: #include < ...
 - UVA - 11214 Guarding the Chessboard (可重复覆盖,DLX+IDA*)
		
题目链接 正解是IDA*+四个方向判重,但由于是个裸的可重复覆盖问题,可以用DLX水过~ 每个格子与放上皇后能干掉的标记连边,跑可重复覆盖DLX.注意要用IDA*来优化,否则会超时. #include ...
 
随机推荐
- 2016NOI冬令营day2
			
早上起来发现头不痛了(还是咳) : | 上午先讲自然语言处理!完全不考!完全不涉及!一开始挺有兴趣,后面就完全听不懂了 : | 后来又讲了几道IOI题目(自称只是op),然后就是 从信息熵到数据压缩 ...
 - INNODB引擎概述
			
INNODB存储引擎的历史概述: INNODB存储引擎是OLTP应用中核心表的首选存储引擎. INNODB存储引擎包含在所有mysql数据库的二进制发行版本中.早期其版本随着mysql数据库的更新而更 ...
 - Django框架介绍之一
			
这片博文就是对django有个大概的了解,通俗的说,就是先让django跑起来. django安装 在linux上安装如下: 源码安装: tar -zxvf Django-1.9.13.tar.gz ...
 - Razor语法快速参考
			
语法/示例 Razor Web Forms对应写法或说明 代码块 @{ int x = 123; string y = "because.";} <% int x = 123 ...
 - hdu 6180 Schedule
			
Schedule Problem Description There are N schedules, the i-th schedule has start time si and end time ...
 - label表单的关联性
			
<input type="checkbox" id="cr" /> <label for="cr">点击关联复选框& ...
 - 获取String类型汉字乱码,如何进行编码
			
本文为博主原创,未经允许不得转载: 在解析properties文件中的汉字时,在java代码中解析得到的是一个乱码字符,形如图下: 导致乱码原因:由于在jdk中,默认为gbk编码方式进行编码盒接收的, ...
 - UVa 11729 突击战
			
https://vjudge.net/problem/UVA-11729 题意:有n个部下,每个部下需要完成一项任务.第i个部下需要你话B分钟交代任务,然后立刻执行J分钟完成任务.安排交代任务顺序并计 ...
 - 用caffe进行图片检索
			
1.图片的处理 输入:将自己的图像转换成caffe需要的格式要求:lmdb 或者 leveldb 格式 这里caffe有自己提供的脚本:create_minst.sh 转换训练图片和验证图片的格式,运 ...
 - Linux 普通用户拿到root权限及使用szrz命令上传下载文件
			
1.如何拿到root权限 在shell里如果看到你的命令输入行最前面显示的是 $符号,说明目前账号只有系统的普通权限. 输入:sudo su 这时能看到shell的输入行最前面已经显示的是#号,说明已 ...