IOI1994 北京2008的挂钟 迭代加深
总的来讲,这是一道很⑨的题,因为:
(1)题目中有⑨个挂钟
(2)有⑨种操作方案
(3)这题因为解空间太小所以可以直接⑨重循环!!
这题可以用迭代加深搜索高效求解,剪枝的策略也很显然:
>所求的操作序列一定是单调不递减的
>同一操作不可能在解中出现4次及以上(操作4次等于没有操作)
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
]={};
]={};
]={};
void move(int _cmd)
{
++cmdCnt[_cmd];
switch(_cmd)
{
: ++dir[]; ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; break;
: ++dir[]; ++dir[]; ++dir[]; ++dir[]; break;
}
}
void undo(int _cmd)
{
--cmdCnt[_cmd];
switch(_cmd)
{
: --dir[]; --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; break;
: --dir[]; --dir[]; --dir[]; --dir[]; break;
}
}
inline bool isDest()
{
;i<=;i++) ) return false;
return true;
}
bool search_aux(int _maxDepth,int _curDepth,int _lastCmd)
{
if(isDest()) return true;
if(_curDepth > _maxDepth) return false;
;i++)
{
)
{
move(i);
,i);
undo(i);
if(next) { ++ans[i]; return true; }
}
}
return false;
}
void input()
{
;i<=;i++) scanf("%d",dir+i);
}
void search()
{
;;i++) ,)) return;
}
void printAns()
{
;i<=;i++)
while(ans[i]--) printf("%d ",i);
}
int main()
{
input();
search();
printAns();
;
}
Cirno is willing to try this problem (*^__^*)
IOI1994 北京2008的挂钟 迭代加深的更多相关文章
- vijosP1016 北京2008的挂钟
vijosP1016 北京2008的挂钟 题目链接:https://vijos.org/p/1016 [思路] Dfs. 对操作搜索更加优秀,所以采用搜索每一个操作的使用次数,因为操作数为4则相当于没 ...
- Vijos——T 1016 北京2008的挂钟 || 洛谷—— P1213 时钟
https://www.luogu.org/problem/show?pid=1213 题目描述 考虑将如此安排在一个 3 x 3 行列中的九个时钟: 目标要找一个最小的移动顺序将所有的指针指向12点 ...
- POJ1129Channel Allocation[迭代加深搜索 四色定理]
Channel Allocation Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 14601 Accepted: 74 ...
- BZOJ1085: [SCOI2005]骑士精神 [迭代加深搜索 IDA*]
1085: [SCOI2005]骑士精神 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1800 Solved: 984[Submit][Statu ...
- 迭代加深搜索 POJ 1129 Channel Allocation
POJ 1129 Channel Allocation Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 14191 Acc ...
- 迭代加深搜索 codevs 2541 幂运算
codevs 2541 幂运算 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 从m开始,我们只需要6次运算就可以计算出 ...
- HDU 1560 DNA sequence (IDA* 迭代加深 搜索)
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1560 BFS题解:http://www.cnblogs.com/crazyapple/p/321810 ...
- usaco4.12Fence Rails(迭代加深)
为了这题还去学了下迭代加深 回来还是不会写 只好参考各大神的代码及题解了 二分枚举最大可以切的块数 然后就是各种分析及优化 USACO题解里写了7个优化.. 问题分析 抽象一下就可以发现,算法的本质是 ...
- poj2286The Rotation Game(迭代加深dfs)
链接 把迭代加深理解错了 自己写了半天也没写对 所谓迭代加深,就是在深度无上限的情况下,先预估一个深度(尽量小)进行搜索,如果没有找到解,再逐步放大深度搜索.这种方法虽然会导致重复的遍历 某些结点,但 ...
随机推荐
- (转载)浅谈javascript的分号
(转载)http://www.blueidea.com/tech/web/2009/7261.asp javascript的分号代表语句的结束符,但由于javascript具有分号自动插入规则,所以它 ...
- 关于 all-delete-orphan
当关联双方存在父子关系,就可以在 set 处设定 cascade 为 all-delete-orphan 所谓父子关系,即指由父方控制子方的持久化圣明周期,子方对象必须和一个父方对象关联.如果删除父方 ...
- Windows作业
1.什么是Windows作业 Windows作业实际上一个进程组,可以给作业设置权限,一旦进程加入到作业内,进程的权限将会被作业限制. 2.创建一个作业 HANDLE CreateJobObject( ...
- 窥探Unity5渲染内部之解析UnityShaderVariables.cginc
unity5的UnityShaderVariables.cginc比unity4大了1kb这里装着unity shader 大部分内部参数,写这个方便以后自己查询 Camera参数 uniform f ...
- Best Premium Private Proxy Service | Lime Proxies
Best Premium Private Proxy Service | Lime Proxies undefined
- 宁波Uber优步司机奖励政策(1月18日~1月24日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- jump_ur.php通知模板
<title>出错啦~~~</title> <script language="javascript" type="text/javascr ...
- 1388 - Graveyard(数论)
题目链接:1388 - Graveyard 题目大意:在一个周长为10000的圆形水池旁有n个等距离的雕塑,现在要再添加m个雕塑,为了使得n + m个雕塑等距离,需要移动一些雕塑,问如何使得移动的总位 ...
- jstree 节点拖拽保存数据库
需要jstree具有拖拽功能需要在加载jstree时添加dnd插件,具体看代码: $('**').jstree({ //plugins-各种jstree的插件引入,展示树的多样性 'plugins' ...
- 设置imageView正方形高宽
private void initWidth() { int screenWidth = ((MyApplication)getApplication()).screenWidth; if(0 == ...