题解:洛谷-P8548 小挖的买花

挺明显的一道板子题。

题目大意

就是普通的二维费用背包,只是会给出 \(q\) 个询问,每个询问给出一个总价格 和一个总新鲜值

我们需要求出在不同的要求下可以获得的最大美丽值

题目分析

回想一下,我们在做这类题目的时候,在计算出最终的答案的过程中,我们是不是也把每个状态的最优解也算出来了?所以,我们可以直接进行一次这样的预处理以获得全部状态的最优解,接下来输出就行了。

动态规划预处理

由于有两个需要注意的量,我们把动态规划数组设为两维的。

设 \(f_{i,j}\) 为使用 \(i\) 费用,新鲜值为 \(j\) 时的最大美丽值。易得方程:

\f_{i,j}=\\max(f_{i,j},f_{{i-cost_k},{j-fr_k}}+be_k) \\

代码实现

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,m,f[1005][1005],tmp1,tmp2;
struct str{
    int cost,fr,be;
}q[505];
signed main()
{
    scanf("%lld%lld",&n,&m);//输入数据
    for(int j=0;j<=500;j++)
    {
        for(int k=1;k<=500;k++) f[j][k]=-0x7fffffff;
    }
    for(int i=1;i<=n;i++) scanf("%lld%lld%lld",&q[i].cost,&q[i].fr,&q[i].be);
    for(int i=1;i<=n;i++)//动态规划预处理
    {
        for(int j=500;j>=q[i].cost;j--)
        {
            for(int k=500;k>=0;k--) f[j][k]=max(f[j][k],f[j-q[i].cost][max(k-q[i].fr,0ll)]+q[i].be);//这里,我们不能直接将k定到q[i].fr以达到无需特判的效果,因为如果它小于0的话我们可以直接使用0的状态进行转移(血的教训呜呜呜)
        }
    }
    for(int i=1;i<=m;i++)//输出答案
    {
        scanf("%lld%lld",&tmp1,&tmp2);
        printf("%lld",max(0ll,f[tmp1][tmp2]));
        if(i!=m)printf("\n");
    }
    return 0;
}
相关推荐
Tisfy18 小时前
LeetCode 3689.最大子数组总值 I:What The Medium
算法·leetcode·题解·贪心·模拟·脑筋急转弯
cpp_25012 天前
P2947 [USACO09MAR] Look Up S
数据结构·c++·算法·题解·单调栈·洛谷
cpp_25016 天前
P11375 [GESP202412 六级] 树上游走
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
cpp_25017 天前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
cpp_25018 天前
P10109 [GESP202312 六级] 工作沟通
数据结构·c++·算法·题解·洛谷·gesp六级
cpp_25018 天前
P10377 [GESP202403 六级] 好斗的牛
数据结构·c++·算法·题解·洛谷·gesp六级
朔北之忘 Clancy10 天前
2026 年 3 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·考级
朔北之忘 Clancy11 天前
2026 年 3 月青少年软编等考 C/C++ 一级真题解析
c语言·开发语言·c++·青少年编程·题解·考级
Tisfy14 天前
LeetCode 3121.统计特殊字母的数量 II:状态机
算法·leetcode·题解·状态机
Tisfy20 天前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表