AcWing 2. 01背包问题

题目描述

解题思路:

相关代码:

复制代码
import java.util.Scanner;
public class Main {

    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        /*
        *  背包问题的物品下标最好从1开始。
        * */
        /*定义一f[i][j]数组,i表示的是前i个物品,j
          表示体积不超过j,值表示最大价值
         */
        int f[][] = new int[1010][1010];
        int v[] = new int[1010];
        int w[] = new int[1010];

        int N = scanner.nextInt();
        int V = scanner.nextInt();

        for(int i=1;i<=N;i++){
            v[i] = scanner.nextInt();
            w[i] = scanner.nextInt();
        }

        for(int i=1;i<=N;i++)
            for(int j=0;j<=V;j++)
                if(j>=v[i]) f[i][j] = Math.max(f[i-1][j],f[i-1][j-v[i]]+w[i]);
                else f[i][j] = Math.max(f[i-1][j],f[i][j]);

        System.out.println(f[N][V]);
    }
}

如果以物品的数量来看待问题,还有另一种解法

相关代码

复制代码
import java.util.Scanner;

public class Main {

    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        /*
        *  背包问题的物品下标最好从1开始。
        * */
        /*定义一f[i][j]数组,i表示的是前i个物品,j
          表示体积不超过j,值表示最大价值
         */
        int f[][] = new int[1010][1010];
        int v[] = new int[1010];
        int w[] = new int[1010];

        int N = scanner.nextInt();
        int V = scanner.nextInt();

        for(int i=1;i<=N;i++){
            v[i] = scanner.nextInt();
            w[i] = scanner.nextInt();
        }

        for(int i=1;i<=N;i++)
            for(int j=0;j<=V;j++)
                for(int k=0;k*v[i]<=j&&k<=1;k++)
                f[i][j] = Math.max(f[i][j],f[i-1][j-k*v[i]]+k*w[i]);
        System.out.println(f[N][V]);
    }
}
相关推荐
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
~|Bernard|3 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师3 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo33 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
好家伙VCC4 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
liulilittle6 小时前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
bkspiderx7 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
中华小当家呐8 小时前
算法之常见八大排序
数据结构·算法·排序算法
沐怡旸9 小时前
【算法--链表】114.二叉树展开为链表--通俗讲解
算法·面试
一只懒洋洋9 小时前
K-meas 聚类、KNN算法、决策树、随机森林
算法·决策树·聚类