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

作者: HeartGo | 来源:发表于2017-02-07 22:56 被阅读306次

0-1背包问题

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

代码如下:

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);
}

}

相关文章

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

    0-1背包问题 在0 / 1背包问题中,需对容量为c 的背包进行装载。从n 个物品中选取装入背包的物品,每件物品i...

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

    0-1背包问题有n个重量分别为{w1,w2,…,wn}的物品,它们的价值分别为{v1,v2,…,vn},给定一个容...

  • 回溯法 0-1背包问题

    题目 给定n个重量为w1w1​,w2w2​,w3w3​,…,wnwn​,价值为v1v1​,v2v2​,v3v3​,...

  • 初识动态规划

    0-1 背包问题 备忘录 动态规划-二维数组 动态规划-一维数组 0-1 背包问题升级版 回溯算法 动态规划-二维...

  • Algorithm进阶计划 -- 动态规划(下)

    经典动态规划背包问题最长子序列问题 1. 背包问题 1.1 0-1 背包问题 0-1 背包问题,描述如下: 上面...

  • 回溯算法---0-1背包问题

    引言:这道题目老师强调了肯定要考,所以只有硬着头皮将其复习了;下面是自己学习回溯算法的学习,仅供参考;一:基本概念...

  • 回溯算法:0-1背包问题

    测试验证: 结果为: 即选择第 2、3、5 个物品,不仅总重量没有超过背包容量,并且总的价值最大为:21

  • 回溯法解决背包问题

    问题描述: 辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师。为此,他想拜附近最有威望的医师为师。医师为了...

  • 背包问题

    背包问题属于典型的动态规划问题。这里我们将详细介绍0-1背包,完全背包和多重背包问题 一、 0-1背包 有N件物品...

  • 算法-动态规划-背包问题

    背包问题是基础的动态规划问题,包含了0-1背包,完全背包,多重背包等。 0-1背包 存在容量为 的背包 , 件体...

网友评论

    本文标题: 0-1背包问题(回溯法)

    本文链接:https://www.haomeiwen.com/subject/sfamittx.html