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]);
    }
}
相关推荐
秋难降7 分钟前
LRU缓存算法(最近最少使用算法)——工业界缓存淘汰策略的 “默认选择”
数据结构·python·算法
CoovallyAIHub2 小时前
线性复杂度破局!Swin Transformer 移位窗口颠覆高分辨率视觉建模
深度学习·算法·计算机视觉
点云SLAM2 小时前
Eigen中Dense 模块简要介绍和实战应用示例(最小二乘拟合直线、协方差矩阵计算和稀疏求解等)
线性代数·算法·机器学习·矩阵·机器人/slam·密集矩阵与向量·eigen库
renhongxia12 小时前
大模型微调RAG、LORA、强化学习
人工智能·深度学习·算法·语言模型
DdduZe3 小时前
8.19作业
数据结构·算法
PyHaVolask3 小时前
链表基本运算详解:查找、插入、删除及特殊链表
数据结构·算法·链表
高山上有一只小老虎3 小时前
走方格的方案数
java·算法
吧唧霸3 小时前
golang读写锁和互斥锁的区别
开发语言·算法·golang