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

相关推荐
dragoooon348 分钟前
优选算法:移动零
c++·学习·算法·学习方法
运维小文20 分钟前
初探贪心算法 -- 使用最少纸币组成指定金额
c++·python·算法·贪心算法
智者知已应修善业1 小时前
【C# 找最大值、最小值和平均值及大于个数和值】2022-9-23
经验分享·笔记·算法·c#
Zz_waiting.2 小时前
Java 算法解析 - 双指针
java·开发语言·数据结构·算法·leetcode·双指针
overFitBrain3 小时前
数据结构-4(常用排序算法、二分查找)
linux·数据结构·算法
Sagittarius_A*3 小时前
【C++】标准模板库(STL)—— 学习算法的利器
c++·学习·算法·stl
我有一计3333 小时前
【大模型微调】7.日志监控配置与模型量化分享
人工智能·算法·程序员
我有一计3334 小时前
【不背八股】1.if __name__ == "__main__" 有什么作用?
人工智能·算法·程序员
野生程序员y4 小时前
谈谈ArrayList与Vector的理解?
算法
前端拿破轮4 小时前
平衡二叉树的判断——怎么在O(n)的时间复杂度内实现?
前端·算法·设计模式