前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >0-1背包问题(回溯法)

0-1背包问题(回溯法)

作者头像
用户2909867
发布2018-08-22 11:01:12
8590
发布2018-08-22 11:01:12
举报
文章被收录于专栏:互联网大杂烩互联网大杂烩

0-1背包问题

在0 / 1背包问题中,需对容量为c 的背包进行装载。从n 个物品中选取装入背包的物品,每件物品i 的重量为wi ,价值为pi 。 对于可行的背包装载,背包中物品的总重量不能超过背包的容量,最佳装载是指所装入的物品价值最高。 本题采用回溯法进行求解:

代码如下:
代码语言:javascript
复制
public class Package {

/**
 * @param args
 */
private int num=10;
int[] W={19,23,12,34,24,34,56,24,53,35};  //背包重量
int[] V={57,68,87,17,12,21,31,42,14,15};   //背包权值
private int[] a=new int[10];
int C=300;
static int MaxValue=0;                   //背包背的最大权值
public static void main(String[] args) {
    // TODO Auto-generated method stub
    Package p=new Package();
    p.ReadData();
    p.Search(0);
    PrintMaxValue();
}
public void ReadData(){
    for(int i=0;i<num;i++){
        System.out.println("弟"+i+"的重量和价值是:"+W[i]+"   "+V[i]);
    }
}

public void Search(int m){
    if(m>=num){
        CheckMax();
    }
    else {
        a[m]=0;
        Search(m+1);
        a[m]=1;
        Search(m+1);
    }

}
public void CheckMax(){
    int Weight=0;
    int Value=0;
    for(int i=0;i<num;i++){             //判断是否到达上限

        if(a[i]==1){
        Weight=Weight+W[i];
        Value=Value+V[i];
        }
    }
    if(Weight<=C){
        if(Value>MaxValue){
            MaxValue=Value;
            System.out.println("最大价值是:"+MaxValue);
        }
    }
}
public static void PrintMaxValue(){
    System.out.println(" 最终的最大价值是:"+MaxValue);
}

}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.02.07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0-1背包问题
    • 代码如下:
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档