洛谷P2577 [ZJOI2005]午餐 dp
正解:序列dp
解题报告:
这题首先要想到一个显然的贪心:每个窗口的排队顺序都是按照吃饭时间从大到小排序的
证明如下:
这种贪心通常都是用微扰法,这题也不例外
现在假如已经确定了每个窗口有哪些人辣,那就是要排除最优顺序使得吃完饭的时间最短
因为两个窗口直接互不影响,所以可以先单独抽出一个窗口来看,就相当于只有一个窗口了
然后选取两个人x,y,设a表示排队时间b表示吃饭时间,令b[x]>b[y]
于是可以列出式子
对于x排在前面,T1=a[x]+max(b[x],a[y]+b[y])
对于y排在前面,T2=a[y]+max(b[y],a[x]+b[x])
因为已经令b[x]>b[y]辣,所以T2=a[y]+a[x]+b[x]
所以T1-T2=max(b[x],a[y]+b[y])-a[y]-b[x]
当b[x]>a[y]+b[y]时,T1-T2=-a[y]<0,T1<T2
当b[x]<a[y]+b[y]时,T1-T2=b[y]-b[x]<0,T1<T2
综上,当x排在前面是T1<T2
所以按照吃饭时间顺序从大到小排是最优的
然后得到了这个贪心之后就变成,已知排队顺序,有两个窗口,求怎么安排时间最小
显然是设f[i][j]:排到第i个人辣一号窗口的排队时间为j的最小吃饭时间
然后记个前缀和sum可以求出二号窗口的排队时间嘛
然后转移就一样是分类讨论走一波就欧克了鸭
还是大概港下QwQ
首先可以到一号窗口,然后到了一号窗口之后有两个情况
第一个是前面的人吃完饭的时间比第i个人的吃饭时间还要长,那就f[i][j+a[i]]=f[i-1][j]
第二个是前面的人吃完饭的时间比第i个人的吃饭时间短一些,那就f[i][j+a[i]]=j+a[i]+b[i]
当然实际上是不用分类讨论的取个max就好QwQ
然后也可以到二号窗口,一样的两个情况一样的思路,懒得详细写辣,反正就max(f[i-1][j],sum[i]-j+a[i]+b[i])
然后放下代码,,,
这个代码是我5个月之前写的辣,,,其实码风差不多,就麻油快读,麻油压行,然后代码里的变量名有点不一样,但思路理顺辣看代码还是比较轻松的辣QwQ所以我就懒得改辣QwQ
over!
#include<bits/stdc++.h>
using namespace std;
][],sum[];
struct str
{
int d,e;
}a[];
bool cmp(str x,str y)
{
return x.e>y.e;
}
int main()
{
cin>>n;
;i<=n;i++)cin>>a[i].d>>a[i].e;
sort(a+,a+n+,cmp);
;i<=n;i++)sum[i]=sum[i-]+a[i].d;
;i<=n;i++)
;j<=sum[n];j++)f[i][j]=;
;
f[][]=;
;i<=n;i++)
;j<=sum[i];j++)
{
][j-a[i].d],j+a[i].e));
f[i][j]=min(f[i][j],max(f[i-][j],sum[i]-j+a[i].e));
}
;j<=sum[n];j++)ans=min(ans,f[n][j]);
cout<<ans;
;
}
洛谷P2577 [ZJOI2005]午餐 dp的更多相关文章
- 洛谷P2577 [ZJOI2005]午餐 打饭时间作为容量DP
P2577 [ZJOI2005]午餐 )逼着自己做DP 题意: 有n个人打饭,每个人都有打饭时间和吃饭时间.有两个打饭窗口,问如何安排可以使得总用时最少. 思路: 1)可以发现吃饭时间最长的要先打饭. ...
- 【题解】洛谷P2577 [ZJOI2005] 午餐(DP+贪心)
次元传送门:洛谷P2577 思路 首先贪心是必须的 我们能感性地理解出吃饭慢的必须先吃饭(结合一下生活) 因此我们可以先按吃饭时间从大到小排序 然后就能自然地想到用f[i][j][k]表示前i个人在第 ...
- [洛谷P2577] [ZJOI2005]午餐
洛谷题目链接:[ZJOI2005]午餐 题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的 ...
- 洛谷 P2577 [ZJOI2005]午餐
这道题目比较难想. 题解: 算法:贪心+dp 容易想到贪心:吃饭慢的先打饭节约时间, 所以先将人按吃饭时间从大到小排序. 然后就是dp了: 首先,应该想到f[i][j][k]:前i个人,在1号窗口打饭 ...
- 洛谷 P2577 [ZJOI2005]午餐 题解
每日一题 day56 打卡 Analysis 算法:贪心+dp 容易想到贪心:吃饭慢的先打饭节约时间, 所以先将人按吃饭时间从大到小排序. 然后就是dp了: 首先,应该想到f[i][j][k]:前i个 ...
- Luogu P2577 [ZJOI2005]午餐(dp)
P2577 [ZJOI2005]午餐 题面 题目描述 上午的训练结束了, \(THU \ ACM\) 小组集体去吃午餐,他们一行 \(N\) 人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时 ...
- BZOJ1899或洛谷2577 [ZJOI2005]午餐
BZOJ原题链接 洛谷原题链接 解决这题得先想到一个贪心:吃饭慢的先排队. 并不会证明(感觉显然 设\(f[i][j][k]\)表示已经排好了前\(i\)人,第一个队伍需要花费的打饭时间为\(j\), ...
- 洛谷 2577 [ZJOI2005]午餐——序列dp
题目:https://www.luogu.org/problemnew/show/P2577 可以从只有一个窗口的角度思考出一个贪心结论.就是应当按吃饭时间(不算打饭时间)从大到小排序.这样交换相邻两 ...
- P2577 [ZJOI2005]午餐[DP]
题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...
随机推荐
- MQTT_DEMO
1 /* 2 Copyright (c) 2009-2012 Roger Light <roger@atchoo.org> 3 All rights reserved. 4 5 Redis ...
- pycharm2016.2.3注册码到期, 激活, 破解版
python工具下载: https://pan.baidu.com/s/1kVEDOrl#list/path=%2F 密码:ko1i 注册码有效期是一年,到期后需再次激活 分享破解版 或者重新注册码激 ...
- 杨辉三角(Pascal Triangle)的几种C语言实现及其复杂度分析
说明 本文给出杨辉三角的几种C语言实现,并简要分析典型方法的复杂度. 本文假定读者具备二项式定理.排列组合.求和等方面的数学知识. 一 基本概念 杨辉三角,又称贾宪三角.帕斯卡三角,是二项式系数在三 ...
- 【Drools-开源业务规则引擎】入门实例(含源码)
该实例转自:http://blog.csdn.net/quzishen/article/details/6163012 便于理解的应用实例1: 现在我们模拟一个应用场景:网站伴随业务产生而进行的积分发 ...
- vue经验 - 细节小知识点汇总(更新中...)
1. $refs 数据这么绑定的: 然后在created中抛出来,猜猜看看打印的是两个什么? 结果如下: 第一个跑出来了,第二个,却undefiend,没有东西?!... 后来去官网查看$refs的解 ...
- 转载->C#事件的使用和讲解
C#事件的使用和讲解 事件的由来 在上一篇幅博客中http://www.cnblogs.com/JiYF/p/6867081.html 对委托讲解的比较细致 我们继续思考上面的程序:上面的三个方法都定 ...
- js json转字符串
在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键.例如:JSON字符串:var str1 = '{ &quo ...
- 在openLdap上添加memberOf属性
我为openldap添加memberof属性的时候参考了这个文章:http://www.adimian.com/blog/2014/10/how-to-enable-memberof-using-op ...
- 备忘,commons-codec中可能用到的一些加密字符串的方法
commons-codec中提供了一些加密解密字符串的方法,我们可以直接使用 1.MD5加密: String source = "source"; DigestUtils.md5H ...
- Power Shell 学习笔记
Powershell 是运行在windows机器上实现系统和应用程序管理自动化的命令行脚本环境. 桌面右击任务栏开始图标,打开控制台对话窗: Windows PowerShell ISE 应用程序的文 ...