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]);
    }
}
相关推荐
二进制person4 小时前
Java SE--方法的使用
java·开发语言·算法
OneQ6664 小时前
C++讲解---创建日期类
开发语言·c++·算法
JoJo_Way5 小时前
LeetCode三数之和-js题解
javascript·算法·leetcode
.30-06Springfield5 小时前
人工智能概念之七:集成学习思想(Bagging、Boosting、Stacking)
人工智能·算法·机器学习·集成学习
凌肖战7 小时前
力扣网C语言编程题:在数组中查找目标值位置之二分查找法
c语言·算法·leetcode
weixin_478689767 小时前
十大排序算法汇总
java·算法·排序算法
luofeiju8 小时前
使用LU分解求解线性方程组
线性代数·算法
SKYDROID云卓小助手8 小时前
无人设备遥控器之自动调整编码技术篇
人工智能·嵌入式硬件·算法·自动化·信号处理
ysa0510309 小时前
数论基础知识和模板
数据结构·c++·笔记·算法
GEEK零零七9 小时前
Leetcode 1103. 分糖果 II
数学·算法·leetcode·等差数列