木棒拼接 poj1011 搜索+剪枝 递归实现

博客介绍了POJ1011问题,这是一个经典的搜索加剪枝问题,主要探讨如何用递归解决。文章讨论了从栈到递归的转变,递归函数的设计思路,以及在拼接过程中需要考虑的参数和递归终止条件。此外,还提到了关键的剪枝策略,包括木棍长度排序、总长度整除性等,以提高搜索效率。
摘要由CSDN通过智能技术生成

木棒拼接,POJ上的1011

题目:http://poj.org/problem?id=1011

 

        经典的搜索+剪枝问题。这题我已经做第三遍了,感觉依旧很晕。说一下,自己对搜索的感觉。以前写搜索算法,总会不自觉的用到栈。比如,迷宫问题,通过压栈保存路径,通过弹栈进行回退。还要设置个标志,保证“不走来时路”。

 

        看了大牛们写的code后,有种醍醐灌顶的感觉:递归形式的写法真简洁!因为这种写法把压栈弹栈的工具交给了complier, 所以代码显得格外清爽。但是,玫瑰虽香,身上带刺。清爽简洁并不代表简单易写。这是,函数的参数、返回值都要反复斟酌。要不断的问自己:函数需要几个参数、有没有返回值、递归终止条件是什么。

 

        针对本题,拼接的过程是一个DFS,即:不断拿木棒尝试,拼好一个再拼下一个。需要知道的参数:当前拼接已获得的木棒长度、已经拼接成功的木棒数、当前正在尝试的木棒编号。拼接的过程需要判断,所以函数返回bool.

 

        在用栈实现时,回退就是不断的弹栈。这里,回退就比较隐晦,只是把已经设置的标记再复原一下。而且,递归调用时也很抽象。只有像binary tree上写递归一样,假设递归调用的部分结果已知,然后才能继续写后面的代码。

 

本题的另一个关键在剪枝,可以用于剪枝的条件:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值