Back Tracking
回溯的处理思想,类似于枚举。我们枚举所有的解,找到满足期望的解。为了有规律地枚举所有的解,避免重复和遗漏,把问题求解的过程分为多个阶段。每个阶段,会有多个选择,随意选择一个,若发现这个选择不满足条件,则回到上一步,做另外一个选择。
比如深度优先遍历即使用的回溯思想。
回溯算法一般适用用递归来实现。剪枝操作是提高回溯效率的一种技巧。
案例
0-1 背包
问题:一个背包总承重 W kg,有 n 个重量不等的物体,选择几件物品装到背包中,使背包中的总重量最大。
注意:此问题与贪心算法中的背包问题区别在于这里的物体不能分割,只能选择装或不装,所以叫做 0-1 问题。此类问题用动态规划效率更高。
思路:用回溯思想的话,若有 n 个物体,把问题分为 n 个阶段,每个阶段对应是否选择物品。可以用一点剪枝技巧,当已经选择的物品超过 W 后,就停止后面的阶段。
正则
Last updated