算法Day23 简单吃饭(0-1背包)

简单吃饭(0-1背包)

Description

Input

Output

Sample

代码

java 复制代码
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int total = scanner.nextInt();
        int price[] = new int[n];
        int high[] = new int[n];
        for(int i =0;i<n;i++){
            price[i] = scanner.nextInt();
            high[i] = scanner.nextInt();
        }
        System.out.println(process(price,high,total));
    }
    public static int process(int price[],int high[],int prices){
        //总计happy
        int dp[][] = new int[price.length+1][prices+1];

        for(int i=1;i<=price.length;i++){
            for(int j=1;j<=prices;j++){
                dp[i][j]=dp[i-1][j];
                if(j>=price[i-1]){
                    dp[i][j]=Math.max(dp[i-1][j],dp[i-1][j-price[i-1]]+high[i-1]);
                }
            }
        }
        return dp[price.length][prices];
    }
}

思路

使用动态规划,与完全吃饭类似

注意的是dp[i][j]=dp[i-1][j]

这样是保证选取的食物有序,对食物仅能选取0-1次

相关推荐
_深海凉_11 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode
被开发耽误的大厨14 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang00732114 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆15 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)16 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野17 小时前
刷题:数组
数据结构·算法
tankeven17 小时前
HJ182 画展布置
c++·算法
CS_Zero19 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵19 小时前
聚酯切片DSC热分析应用报告
人工智能·算法
@BangBang19 小时前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先