中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > 综合其它
算法连载(6)--分支限界法之LC 0/1背包
作者:未知 时间:2005-07-27 23:18 出处:CSDN 责编:chinaitpower
              摘要:算法连载(6)--分支限界法之LC 0/1背包

1.问题描述:已知有N个物品和一个可以容纳M重量的背包,每种物品I的重量为WEIGHT,一个只能全放入或者不放入,求解如何放入物品,可以使背包里的物品的总效益最大。

2.设计思想与分析:对物品的选取与否构成一棵解树,左子树表示不装入,右表示装入,通过检索问题的解树得出最优解,并用结点上界杀死不符合要求的结点。

(多谢shadow同学提供该算法)

#include <iostream.h>

struct good
{
 int weight;
 int benefit;
 int flag;//是否可以装入标记
};

int number=0;//物品数量
int upbound=0;
int curp=0, curw=0;//当前效益值与重量
int maxweight=0;
good *bag=NULL;

void Init_good()
{
 bag=new good [number];

 for(int i=0; i<number; i++)
 {
  cout<<"请输入第件"<<i+1<<"物品的重量:";
  cin>>bag[i].weight;
  cout<<"请输入第件"<<i+1<<"物品的效益:";
  cin>>bag[i].benefit;
  bag[i].flag=0;//初始标志为不装入背包
  cout<<endl;
 }

}

int getbound(int num, int *bound_u)//返回本结点的c限界和u限界
{
 for(int w=curw, p=curp; num<number && (w+bag[num].weight)<=maxweight; num++)
 {
  w=w+bag[num].weight;
  p=w+bag[num].benefit;
 }

 *bound_u=p+bag[num].benefit;
 return ( p+bag[num].benefit*((maxweight-w)/bag[num].weight) );
}

void LCbag()
{
 int bound_u=0, bound_c=0;//当前结点的c限界和u限界

 for(int i=0; i<number; i++)//逐层遍历解树决定是否装入各个物品
 {
  if( ( bound_c=getbound(i+1, &bound_u) )>upbound )//遍历左子树
    upbound=bound_u;//更改已有u限界,不更改标志  

  if( getbound(i, &bound_u)>bound_c )//遍历右子树
  //若装入,判断右子树的c限界是否大于左子树根的c限界,是则装入
  {
   upbound=bound_u;//更改已有u限界
   curp=curp+bag[i].benefit;
   curw=curw+bag[i].weight;//从已有重量和效益加上新物品
   bag[i].flag=1;//标记为装入
  }
 }

}

void Display()
{

 cout<<"可以放入背包的物品的编号为:";
 for(int i=0; i<number; i++)
  if(bag[i].flag>0)
   cout<<i+1<<" ";
  cout<<endl;
  delete []bag;
}


关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有