HDU 1195 Open the Lock

        题目大意:有一个紧急开启密码锁的任务。密码由四位数字组成;每个数字从19;每次,可以对每一个数字进行加1或者减1;当从1加到9时,由9再加1会变为1;当从9减到1时,由1再减1会变为9;也可以交换两个相邻的数字,每次操作作为一个step。你的任务就是用最少的步骤解锁!


        先来分析一下这道题目: (别人分析的,我觉得分析的好,摘抄一下) 
  1. 首先考虑1234的下一step有可能是什么样的数字   
  2. 针对每一位数字有四种操作,+1,-1,左交换,右交换(最左边的数字只有右交换,最右边只有左交换)   
  3. 那么下一step的数字   
  4. 第一数字位:2234,9234,2134  
  5. 第二数字位:1334,1134,2134,1324  
  6. 第三数字位:1244,1224,1324,1243  
  7. 第四数字位:1235,1233,1243 

       到这里我发现,其实这种搜索的方法就像一般显示图里的方向一样,只不过这里把方向改为方式(搞ACM还得脑子反映灵敏点)!真他妈巧妙。那分析到这里,这题就一清二楚了!

       PS:搜索是一个博大精深的算法,尤其是其思想。熟练的掌握ACM搜索的三种方法对处理大多数问题都会得心应手!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值