回溯法解决01背包问题方案.pptVIP

  • 352
  • 0
  • 约3.91千字
  • 约 21页
  • 2016-05-26 发布于湖北
  • 举报
回溯法解决01背包问题 回溯法解决01背包问题 1、算法思想 2、问题描述 3、设计实现 回溯法解决01背包问题 回溯法:是一个既带有系统性又带有跳跃性的的搜索算法。它在包含问题的所有解的解空间树中,按照深度优先的策略,从根结点出发搜索解空间树。算法搜索至解空间树的任一结点时,总是先判断该结点是否肯定不包含问题的解。如果肯定不包含,则跳过对以该结点为根的子树的系统搜索,逐层向其原先结点回溯。否则,进入该子树,继续按深度优先的策略进行搜索。 课堂上老师已经讲解过用回溯法解决n-皇后问题,m-图着色问题以及哈密顿环问题,他们有相同的特征即问题的求解目标都是求满足约束条件的全部可行解。而0/1背包是最优化问题,还需要使用限界函数剪去已能确认不含最优答案结点的子树。 回溯法解决0/1背包问题 运用回溯法解题通常包含以下三个步骤: a. 针对所给问题,定义问题的解空间; b. 确定易于搜索的解空间结构; c. 以深度优先的方式搜索解空间,并且在搜索过程中用剪枝函数避免无效搜索; 0/1背包问题概述 在0/1背包问题中,需对容量为c的背包进行装载。从n个物品中选取装入背包的物品,每件物品 i的重量为wi, 价值为pi。对于

文档评论(0)

1亿VIP精品文档

相关文档