总的来讲,这是一道很⑨的题,因为:

(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的挂钟 迭代加深的更多相关文章

  1. vijosP1016 北京2008的挂钟

    vijosP1016 北京2008的挂钟 题目链接:https://vijos.org/p/1016 [思路] Dfs. 对操作搜索更加优秀,所以采用搜索每一个操作的使用次数,因为操作数为4则相当于没 ...

  2. Vijos——T 1016 北京2008的挂钟 || 洛谷—— P1213 时钟

    https://www.luogu.org/problem/show?pid=1213 题目描述 考虑将如此安排在一个 3 x 3 行列中的九个时钟: 目标要找一个最小的移动顺序将所有的指针指向12点 ...

  3. POJ1129Channel Allocation[迭代加深搜索 四色定理]

    Channel Allocation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 14601   Accepted: 74 ...

  4. BZOJ1085: [SCOI2005]骑士精神 [迭代加深搜索 IDA*]

    1085: [SCOI2005]骑士精神 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1800  Solved: 984[Submit][Statu ...

  5. 迭代加深搜索 POJ 1129 Channel Allocation

    POJ 1129 Channel Allocation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 14191   Acc ...

  6. 迭代加深搜索 codevs 2541 幂运算

    codevs 2541 幂运算  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题目描述 Description 从m开始,我们只需要6次运算就可以计算出 ...

  7. HDU 1560 DNA sequence (IDA* 迭代加深 搜索)

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1560 BFS题解:http://www.cnblogs.com/crazyapple/p/321810 ...

  8. usaco4.12Fence Rails(迭代加深)

    为了这题还去学了下迭代加深 回来还是不会写 只好参考各大神的代码及题解了 二分枚举最大可以切的块数 然后就是各种分析及优化 USACO题解里写了7个优化.. 问题分析 抽象一下就可以发现,算法的本质是 ...

  9. poj2286The Rotation Game(迭代加深dfs)

    链接 把迭代加深理解错了 自己写了半天也没写对 所谓迭代加深,就是在深度无上限的情况下,先预估一个深度(尽量小)进行搜索,如果没有找到解,再逐步放大深度搜索.这种方法虽然会导致重复的遍历 某些结点,但 ...

随机推荐

  1. Server.Transfer方法,Server.Execute方法和Response.Redirect方法有什么异同

    (1)Server.Transfer方法: Server.Transfer("m2.aspx");//页面转向(服务器上执行). 服务器停止解析本页,保存此页转向前的数据后,再使页 ...

  2. MySQL中的类Decode用法

    SELECT DISTINCT ( CASE ' THEN '关羽' ' THEN ' 张飞' ' THEN ' 赵云' ' THEN ' 马超' ' THEN ' 黄忠' ' THEN ' 魏延' ...

  3. 换成gnome3桌面后国际版qq不能输入中文问题

    困扰了好久的问题今天终于解决了,网上也没有完整的教程,所以在这里整理下 前几天给自己的ubuntu装上了gnome桌面,一切都挺正常的,桌面很炫,用着也很舒服,不过之前的qq却没办法输入中文了,下面我 ...

  4. TCP11种状态分析和测试

    -->简介 -->正文 -->测试一些状态 --------------------------------------------------------------------- ...

  5. UVa10047 The Monocycle

    UVa10047 The Monocycle 链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=19491 (以上摘自htt ...

  6. TCP协议状态简介

    原文出自:Vimer的程序世界 1.建立连接协议(三次握手)(1)客户端发送一个带SYN标志的TCP报文到服务器.这是三次握手过程中的报文1.(2) 服务器端回应客户端的,这是三次握手中的第2个报文, ...

  7. 佛山Uber优步司机奖励政策(1月18日~1月24日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  8. Abator自动生成ibatis的相关配置和类

      一.abator自动生成配置: abator自动生成ibatis的配置文件.mode.sqlMap.dao.bean实例 准备: 1.安装Eclipse插件:      要求eclipse3.1, ...

  9. WCF 项目应用连载[2] - 创建Lig日志系统

    WCF 项目应用连载[1] - 索引 - 轻量级的Log系统 - Lig Sample -序 现在我们创建一个Lig工程 - Litelog 2.1 创建Lig服务 _________________ ...

  10. IOS开发中ARC下的assign和weak区别

    在ARC中的assign和weak可以说非常相像,导致有很多人误以为他们是一摸一样的,在任何时候都可以划等价,但事实却不是这样. 在群里,有人问,id类型的delegate属性到底是用assign还是 ...