算法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次

相关推荐
有意义2 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
用户726876103373 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect4 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
ZhengEnCi1 天前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记1 天前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan1 天前
AI小镇 - 涌现
算法·架构
AI工程架构师1 天前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
祈安_1 天前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮2 天前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling2 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法