【[ZJOI2005]午餐】
首先我们得贪心一下,让吃饭时间较长的人排在队首
去抄一段贪心的证明吧
现在研究在一个队伍里的人有什么性质
可以发现道题里也有一个不变量,就是对于队伍里的前\(i\)个人,不管他们排队的顺序如何,\(a[i]\)的前缀和\(s[i]\)是不会变的,第\(i\)个人会在\(s[i]+b[i]\)时刻吃完,这前\(i\)个人的吃饭时间是\(max(s[j]+b[j])\)
现在可以回到贪心的问题上了,假设对于两个相邻的人\(i\)和\(i+1\),如果\(a[i]==a[i+1]\),那么显然让\(b[i]>b[i+1]\)好
由上面的性质可以看到\(s[i]\)是守恒的,那么让第\(i\)个人的\(b[i]\)是前\(i\)个人里最小的当然就是坠吼的啦
之后就可以dp了
感觉自己dp的姿势不太对
最开始yy出来的状态是\(dp[i][j]\)表示前\(i\)个人里\(j\)个人去了一个队列时消耗时间最长的人的最小耗时
但是这个状态显然不对,因为我们不知道这\(j\)个人的总的等待时间,好想没有什么办法进行转移
于是缺一个状态就加上一维吧,那就用\(dp[i][j][k]\)表示前\(i\)个人里\(j\)个人去了一个队列时等待时间为\(k\)消耗时间最长的人的最小耗时
发现这样的话空间好像要炸的样子,尽管开滚动好像都不太行
但是又发现第二维好像没有什么存的必要,因为转移的时候根本就跟这个队列里有多少人没有关系
于是最后的状态就是\(dp[i][j]\)表示前\(i\)个人里一个队列总等待时间为\(k\)消耗时间最长的人的最小耗时
我们考虑一下如何转移,因为这两个队列本质是相同的,所以一个人有两种选择,一个就是进入在状态里表示的那个队列,在一个就是进入另一个队列
进入状态里表示的这个队列的话,这个队列的总时长会增加,等待时间最长的人可能也会有变化
于是就有
\]
进入另外一个队列,这个队列的等待时长没有变化,但是我们需要知道另外一个队列所有人的总等待时间,由于我闷知道这个队列的总等待时间是\(j\),那么我们用一个前缀和就能求出来另外一个队列的总等待时间
\]
代码
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#define re register
#define maxn 205
#define INF 336860180
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
struct Node
{
int a,b;
}t[maxn];
int n;
int dp[201][200*200+1];
int pre[maxn];
int o;
inline int read()
{
char c=getchar();
int x=0;
while(c<'0'||c>'9') c=getchar();
while(c>='0'&&c<='9')
x=(x<<3)+(x<<1)+c-48,c=getchar();
return x;
}
inline int cmp(Node AA,Node BB)
{
return AA.b>BB.b;
}
int main()
{
n=read();
for(re int i=1;i<=n;i++)
t[i].a=read(),t[i].b=read();
std::sort(t+1,t+n+1,cmp);
for(re int i=1;i<=n;i++)
pre[i]=pre[i-1]+t[i].a;
memset(dp,20,sizeof(dp));
dp[1][t[1].a]=t[1].a+t[1].b;
for(re int i=2;i<=n;i++)
{
for(re int j=0;j<=200*200;j++)
{
if(dp[i-1][j]==INF) continue;
dp[i][j+t[i].a]=min(max(dp[i-1][j],j+t[i].a+t[i].b),dp[i][j+t[i].a]);
dp[i][j]=min(dp[i][j],max(dp[i-1][j],pre[i-1]-j+t[i].a+t[i].b));
}
}
int ans=INF;
for(re int i=1;i<=200*200;i++)
ans=min(ans,dp[n][i]);
std::cout<<ans;
return 0;
}
【[ZJOI2005]午餐】的更多相关文章
- [洛谷P2577] [ZJOI2005]午餐
洛谷题目链接:[ZJOI2005]午餐 题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的 ...
- [ZJOI2005]午餐 (DP)
[ZJOI2005]午餐 题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口 ...
- 洛谷P2577 [ZJOI2005]午餐 打饭时间作为容量DP
P2577 [ZJOI2005]午餐 )逼着自己做DP 题意: 有n个人打饭,每个人都有打饭时间和吃饭时间.有两个打饭窗口,问如何安排可以使得总用时最少. 思路: 1)可以发现吃饭时间最长的要先打饭. ...
- Luogu P2577 [ZJOI2005]午餐(dp)
P2577 [ZJOI2005]午餐 题面 题目描述 上午的训练结束了, \(THU \ ACM\) 小组集体去吃午餐,他们一行 \(N\) 人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时 ...
- 2018.09.22 ZJOI2005午餐(贪心+01背包)
描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各有不 ...
- P2577 [ZJOI2005]午餐 状压DP
题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...
- P2577 [ZJOI2005]午餐
题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...
- 【洛谷P2577】[ZJOI2005]午餐
午餐 题目链接 DP题都辣么毒瘤的么.. 首先,看一下题解 我们就有了思路: 贪心:显然,让吃饭慢的先打饭,sort一遍(证明?不存在的.. DP:f[i][j][k]表示前i个人,窗口1的打饭时间为 ...
- [ZJOI2005]午餐 (贪心,动态规划)
题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...
- P2577 [ZJOI2005]午餐[DP]
题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...
随机推荐
- VMware workstation 虚拟机安装Windows Server 2008 r2
问题秒速: VMware workstation 虚拟机安装Windows Server 2008 r2,配置好参数后,选择开机,报错,错误如图:
- WES7 定制界面完整过程(去除所有windows标识)
转载但有改动 红色字体记录 目的:实验从启动开始到出现桌面,不出现任何windows图标或标识.重大提示:在某些虚拟机上面操作和真实机器是不一样的,主机会容易很多;所以在虚拟机无法实现效果的时候使用主 ...
- golang学习之文件上传
首先是上传页面upload.html: <!doctype html> <html> <head> <meta charset="utf-8&quo ...
- Node.js学习笔记(四) --- fs模块的使用
目录 . fs.stat 检测是文件还是目录 . fs.mkdir 创建目录 . fs.writeFile 创建写入文件 . fs.appendFile 追加文件 . fs.readFile 读取文件 ...
- Octotree Chrome安装与使用整理
Octotree Chrome作用: 主要使你在github查看项目时可以清晰明了的看到项目的结构以及具体代码,使下载代码更具有目的性,减少不必要代码的下载,而且看起来更清楚. 效果图:(安装插件前) ...
- 互联网轻量级框架SSM-查缺补漏第九天
简言: 第九章 Spring Ioc的概念 IoC(Inversion of Control)控制反转:比如想喝橙汁,在没有饮品店的日子,最直观的做法是买果汁机.橙汁.这是你自己“主动”创造的过程,也 ...
- https、公钥、私钥白话解说
原文 摘要:本文尝试一步步还原HTTPS的设计过程,以理解为什么HTTPS最终会是这副模样.但是这并不代表HTTPS的真实设计过程.在阅读本文时,你可以尝试放下已有的对HTTPS的理解,这样更利于“还 ...
- jquery对象与核心函数
原生js入口函数与jQuery入口函数的区别 1.window.onload与document.ready在加载时间上的差异 document.ready会先触发,其次才是window.onload ...
- cf449D. Jzzhu and Numbers(容斥原理 高维前缀和)
题意 题目链接 给出\(n\)个数,问任意选几个数,它们\(\&\)起来等于\(0\)的方案数 Sol 正解居然是容斥原理Orz,然而本蒟蒻完全想不到.. 考虑每一种方案 答案=任意一种方案 ...
- vue中数组删除,页面没重新渲染
创建一个组件时,数据类型是数组,在删除这个数组中的数据时,数组中的数据是对的,但页面渲染的数据却不对. 举例:(不一定复现) <ul> <li v-for="(item, ...