实验报告分支限界法01背包.pdf

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《算法设计与分析》实验报告六 学号: 1004091130 姓名: 金玉琦 日期: 2011-11-17 得分: 一、实验 内容: 运用分支限界法解决 0-1 背包 问题 。 二、所用算法的基本思想及复 杂度分析: 分支限界法 分支限界法按广度优先策略遍历问题的解空间树 , 在遍历过程中 , 对已经处理的 每一个结点根据限界函数估算目标函数的可能取值 , 从中选取使目标函数取得极值 的结点优先进行广度优先搜索 , 从而不断调整搜索方向 , 尽快找到问题的解。因为限 界函数常常是基于问题的目标函数而确定的 , 所以 , 分支限界法适用于求解最优化问 题。 0-1 背包问题 1)基本思想 给定 n 种物品和一个容量为 C 的背包 , 物品 i 的重量是 Wi , 其价值为 Vi , 0/ 1 背包问题是如何选择装入背包的物品 ( 物品不可分割 ) , 使得装入背包中物品的总价值 最大,一般情况下 , 解空间树中第 i 层的每个结点 , 都代表了对物品 1~ i 做出的某 种特定选择 , 这个特定选择由从根结点到该结点的路径唯一确定 : 左分支表示装入物 品, 右分支表示不装入物品。对于第 i 层的某个结点 , 假设背包中已装入物品的重量 w v 是 , 获得的价值是 , 计算该结点的目标函数上界的一个简单方法是把已经装入背包 中的物品取得的价值 v , 加上背包剩余容量 W- w 与剩下物品的最大单位重量价值 vi + 1/ wi + 1 的积 , 于是 , 得到限界函数 : u b = v + ( W- w) × ( vi + 1/ wi + 1 ) 根据限界函数确定目标函数的界 [ down , up] ,然后 , 按照广度优先策略遍历问题的 空 间树。 2 )复杂度分析 n 时间复杂度是 O(2 ); 3、源程序及注 释 : #includeiostream #includecstdio #includeconio.h #includeiomanip 1 using namespace std; int *x; struct node { // 结点表结点数据结构 node *parent,// 父结点指针 *next; // 后继结点指针 int level,// 结点的层 bag,// 节点的解 cw,// 当前背包装载量 cp;// 当前背包价值 float ub; // 结点的上界值 }; class Knap { private: struct node *front, // 队列队首

文档评论(0)

二哥 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档