原题链接

小挖的买花

题目背景

小挖喜欢买花,但是 ta 太懒了!所以这个任务全权交给了你。

题目描述

花店里只有 \(n\) 株花,每一株花都有三个属性:价格 \(cost_i\)、美丽度 \(be_i\)、新鲜程度 \(fr_i\)。

小挖每次都有不同的要求。准确来说,对于第 \(j\) 次买花,你手里的钱至多能买下总价为 \(c_j\) 的花。同时,小挖还要求购买花的新鲜程度总和大于等于 \(f_j\)。而小挖希望知道,在满足 ta 给出的条件后,购买花的美丽度总和的最大值是多少?

小挖一共要让你买 \(q\) 次花,你能否正确回答 ta 的问题呢?

询问显然彼此独立。

输入格式

第 \(1\) 行,共两个数 \(n,q\) 。

第 \(2\sim n+1\) 行,每行三个数 \(cost_i,fr_i,be_i\),分别表示一株花的三个属性。

第 \(n+2\sim n+q+1\) 行,每行两个数 \(c_j,f_j\) ,表示每次买花时的要求。

输出格式

共 \(q\) 行,每行一个数,表示美丽度总和的最大值。

样例 #1

样例输入 #1

5 1
2 4 5
4 3 3
1 3 2
3 4 3
3 2 5
10 10

样例输出 #1

15

提示

对于 \(20\%\) 的数据,\(3\leq n,q\leq 16\)。

对于 \(40\%\) 的数据,\(3\leq n,q\leq 30,0\leq c_j,f_j\leq 50\)。

对于 \(60\%\) 的数据,\(3\leq n\leq 100,1\leq q\leq 5\times 10^4,0\leq cost_i,fr_i,c_j,f_j\leq 100\)。

对于另外 \(20\%\) 的数据,对于每次买花,都有 \(f_j=0\)。

对于 \(100\%\) 的数据,\(3\leq n\leq 500,\boldsymbol{1\leq q\leq 10^6},0\leq cost_i,fr_i,c_j,f_j\leq 500, 1\leq be_i \leq 10^6\)。

审题

第一眼看到“费用”,“新鲜度”这两个指标,像极了二维费用的背包问题。不由得想到二维背包的经典例题:潜水员

但是本题和潜水员又有差别。因为潜水员一题中,两种付出代价的要求都是“至少”,即氧气、氮气都不能低于某一下限。而本题的特殊之处在于,指标“价格”要求不能超过上限,指标“新鲜度”不能低于下限。

思路

我们还是借用常规思想,用\(dp[i][j]\)来表示花费\(i\)的费用,在新鲜度为\(j\)的情况下,能获得的最大美丽度

状态转移方程

1.初始化:\(dp[i][j]=0\)

2.设计循环:

for(i=1~n,i++)//遍历花的种类
for(j=c~cost[i],j--)//遍历价格
for(k=f~0,k--)//遍历新鲜度

3.设计转移方程:

(1)若当前状态的新鲜度可以用第\(i\)种花卉直接满足,即\(k<=fr[i]\),则\(dp[j][k]=maxx(dp[j-cost[i]][0]+be[i],dp[j][k])\)

(2)若当前状态由上一个状态+第\(i\)种花卉转移过来,即\(dp[j-cost[i]][k-fr[i]]!=0\),则\(dp[j][k]=maxx(dp[j][k],dp[j-cost[i]][k-fr[i]]+be[i])\)

if(k<=fr[i])
{
dp[j][k]=maxx(dp[j-cost[i]][0]+be[i],dp[j][k]);
}
else if(dp[j-cost[i]][k-fr[i]])
{
dp[j][k]=maxx(dp[j][k],dp[j-cost[i]][k-fr[i]]+be[i]);
}

4.优化:

题目中有一句话:“询问显然彼此独立”,那是不是意味着我们需要每一组询问都跑一遍\(dp\)呢?显然不是的。

我们可以统计出所有询问中最大的\(c\),记作\(maxc\);统计出最大的\(f\),记作\(maxf\)。

我们只需要跑一次\(dp\),得到\(dp[maxc][maxf]\)的结果。试想一下,若\(dp[maxc][maxf]\)跑出来了,那么\(dp[1][1],dp[1][2]...dp[i][j]...dp[maxc][maxf]\)的结果不就都出来了吗~

AC代码

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
template <typename T>inline void re(T &x) {
x=0;
int f=1;
char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-f;
for(;isdigit(c);c=getchar()) x=(x<<3)+(x<<1)+(c^48);
x*=f;
return;
}
template <typename T>void wr(T x) {
if(x<0) putchar('-'),x=-x;
if(x>9) wr(x/10);
putchar(x%10^'0');
return;
}
int maxx(int a,int b)
{
return a>b?a:b;
}
const int N=505;
int n,q;
int dp[N][N];
int cost[N],fr[N],be[N];
signed main()
{
re(n);re(q);
for(int i=1;i<=n;++i)
{
re(cost[i]);re(fr[i]);re(be[i]);
}
for(int x=1;x<=q;++x)
{
memset(dp,0,sizeof(dp));
int c,f;
re(c);re(f);
for(int i=1;i<=n;++i)
for(int j=c;j>=cost[i];j--)
for(int k=f;k>=0;k--)
{
if(k<=fr[i])
{
dp[j][k]=maxx(dp[j-cost[i]][0]+be[i],dp[j][k]);
}
else if(dp[j-cost[i]][k-fr[i]])
{
dp[j][k]=maxx(dp[j][k],dp[j-cost[i]][k-fr[i]]+be[i]);
}
}
printf("%d\n",dp[c][f]);
}
return 0;
}

P8548 小挖的买花 方法记录的更多相关文章

  1. EF里查看/修改实体的当前值、原始值和数据库值以及重写SaveChanges方法记录实体状态

    本文目录 查看实体当前.原始和数据库值:DbEntityEntry 查看实体的某个属性值:GetValue<TValue>方法 拷贝DbPropertyValues到实体:ToObject ...

  2. 64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录

    64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录 经过几天不停的网上找资料,实验,终于联通了. 环境:系统:win 2008 ,SqlServer2008 R2, 连接O ...

  3. 微信小程序数据请求方法wx.request小测试

    微信小程序数据请求方法 wx.request wxml文件: <view> <textarea value="{{textdata}}"/> </vi ...

  4. js实用方法记录-js动态加载css、js脚本文件

    js实用方法记录-动态加载css/js 附送一个加载iframe,h5打开app代码 1. 动态加载js文件到head标签并执行回调 方法调用:dynamicLoadJs('http://www.yi ...

  5. js实用方法记录-简单cookie操作

    js实用方法记录-简单cookie操作 设置cookie:setCookie(名称,值,保存时间,保存域); 获取cookie:setCookie(名称); 移除cookie:setCookie(名称 ...

  6. win10 系统右键菜单不显示文字(只有小图标)修复方法

    如下图,win10点击鼠标右键调出菜单时,看不到菜单的文字,只显示了小图标. 解决方法: Cortana 搜索 cmd ,看到 命令提示符,右键,选择 以管理员身份运行. 在命令提示符里输入以下命令, ...

  7. js实用方法记录-指不定哪天就会用到的js方法

    js实用方法记录-指不定哪天就会用到的js方法 常用或者不常用都有 判断是否在微信浏览器中 测试代码:isWeiXin()==false /** * 是否在微信中 */ function isWeix ...

  8. rt-thread中动态内存分配之小内存管理模块方法的一点理解

    @2019-01-18 [小记] rt-thread中动态内存分配之小内存管理模块方法的一点理解 > 内存初始化后的布局示意 lfree指向内存空闲区首地址 /** * @ingroup Sys ...

  9. easyui toopTip,鼠标划过悬浮,显示一个小提示框的方法

    easyui toopTip,鼠标划过悬浮,显示一个小提示框的方法 /*easyui,鼠标划过悬浮,显示一个小提示框的方法*/ function toopTip(idOrClass,showText) ...

随机推荐

  1. 用kubeadm简单部署k8s

    一.环境准备 1.三台CentOS6.7虚拟机 master:192.168.0.54 注意:主节点最好是2颗cpu,否则在k8s控制平面初始化的时候会报错: node1:192.168.0.68 n ...

  2. python 操作xml、html文件

    简介 在一些项目中可能会使用到解析html文件,尤其是爬虫相关的,需要解析获取到的html内容,通常我们会使用lxml模块去进行html文件的解析. html文件 当前存在一个简单的html < ...

  3. 获取某个html元素相对于视窗的位置集合

    getBoundingClientRect() getBoundingClientRect()获取元素位置,这个方法没有参数 getBoundingClientRect()用于获得页面中某个元素的左, ...

  4. YII学习总结5(视图)

    <?php namespace app\controllers; use yii\web\Controller; class HelloController extends Controller ...

  5. 【原创】Magisk Root隐藏模块 Shamiko安装

    本文所有教程及源码.软件仅为技术研究.不涉及计算机信息系统功能的删除.修改.增加.干扰,更不会影响计算机信息系统的正常运行.不得将代码用于非法用途,如侵立删! Root隐藏模块 Shamiko安装 操 ...

  6. JUC源码学习笔记4——原子类,CAS,Volatile内存屏障,缓存伪共享与UnSafe相关方法

    JUC源码学习笔记4--原子类,CAS,Volatile内存屏障,缓存伪共享与UnSafe相关方法 volatile的原理和内存屏障参考<Java并发编程的艺术> 原子类源码基于JDK8 ...

  7. Win32 - 窗口

    Win32 - 窗口 目录 Win32 - 窗口 前言 流程图 创建项目 VS MinGW Win32API字符串 Unicode 和 ANSI 函数 TCHAR WinMain:Win32 Appl ...

  8. jQuery 选择器选中某节点,在后续的链式操作函数内使用 $(this) 的结果是 Window 对象,而非该节点对象

    <ul class="tree-ocx"> <li class="tree-ocx-li" data-displayed="fals ...

  9. 从0搭建Vue3组件库:button组件

    button组件几乎是每个组件库都有的:其实实现一个button组件是很简单的.本篇文章将带你一步一步的实现一个button组件.如果你想了解完整的组件库搭建,你可以先看使用Vite和TypeScri ...

  10. HTML(下)

    (一)表格标签 1.表格的作用 用于显示.展示数据,让数据更加规整,可读性更好,把繁琐的数据表现得很有条理,表格不是用来布局页面的,而是用来展示数据的 2.表格标签基本语法 table--table ...