- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)