zoukankan      html  css  js  c++  java
  • 0/1背包-递归算法

    问题描述:

    有n个物品,它们有各自的体积和价值,现有给定容量的背包,如何让背包里装入的物品具有最大的价值总和?

    总体思路:

    针对每个物品只有选与不选。

    1. 判断背包容量是否能承载第n个物品。

    不能承载:判断下一个物品     能承载:选择 装 还是 不装。不装,判断下一个物品;装,背包容量-物品重量,现有价值+物品价值,判断下一个物品。

    2. 当所有物品都判断完或者背包容量为0则当前递归结束。

     

     

    代码:

    #include<stdio.h>
    
    int maxNum[6];  //存放最优解的编号
    int maxValue=0; //存放最大价值
    int w[6] = {0,2,2,6,5,4};//每个物品的重量,第一个为0,方便角标对应
    int v[6] = {0,6,3,5,4,6};//每个物品的价值,第一个为0,方便角标对应
    int num = 5; //物品的个数
    int cap = 10; //背包能承载的重量
    
    void package01(int *flag,int n,int c,int nowValue) //nowvalue(现有价值)
    {
        int i;
        if(n == 0 || c == 0)  //当所有物品判断后 或者 背包容量为0时
        {
            if(nowValue > maxValue)
            {
                for(i=0;i<6;i++)
                    maxNum[i] = flag[i];
                maxValue = nowValue;
            }
            return;
        }
        if(c >= w[n])
        {
            flag[n] = 1;//第n物品被选
            package01(flag, n-1, c-w[n], nowValue+v[n]);
        }
        flag[n] = 0;//第n物品没选
        package01(flag, n-1, c, nowValue);
    }
    int main()
    {
        int flag[6] = {0,0,0,0,0,0};//标记选择的物品
        int i;
        package01(flag,num,cap,0);
        for(i=1;i<=num;i++)
            maxNum[i] == 1 ? printf("第%d号货物装了包中  
    ",i) : 0;
        printf("最大价值为:%d  
    ",maxValue);
    }
  • 相关阅读:
    试题 历届试题 整数拼接(数位dp)
    试题 历届试题 波动数列(dp)
    序列化二叉树(模拟)
    对于maven中无法加载类路径下的配置文件
    [蓝桥杯][算法训练]文章翻转
    [蓝桥杯][算法训练] 无权最长链
    [蓝桥杯][基础训练]2n皇后问题
    蓝桥杯 基础练习——Huffuman树
    蓝桥杯 基础练习——高精度加法
    蓝桥杯 基础练习——阶乘计算
  • 原文地址:https://www.cnblogs.com/xxaf/p/12785232.html
Copyright © 2011-2022 走看看