[NOIP2011 提高组] 观光公交

题目背景

感谢 @Transhumanist 提供的一组 Hack 数据

题目描述

风景迷人的小城 Y 市,拥有 n n n 个美丽的景点。由于慕名而来的游客越来越多,Y 市特意安排了一辆观光公交车,为游客提供更便捷的交通服务。观光公交车在第 0 0 0 分钟出现在 1 1 1 号景点,随后依次前往 2 , 3 , 4 , ⋯ , n 2,3,4,\cdots,n 2,3,4,⋯,n 号景点。从第 i i i 号景点开到第 i + 1 i+1 i+1 号景点需要 D i D_i Di​ 分钟。任意时刻,公交车只能往前开,或在景点处等待。

设共有 m m m 个游客,每位游客需要乘车 1 1 1 次从一个景点到达另一个景点,第 i i i 位游客在 T i T_i Ti​ 分钟来到景点 A i A_i Ai​,希望乘车前往景点 B i B_i Bi​( A i < B i A_i<B_i Ai​<Bi​)。为了使所有乘客都能顺利到达目的地,公交车在每站都必须等待需要从该景点出发的所有乘客都上车后才能出发开往下一景点。

假设乘客上下车不需要时间。一个乘客的旅行时间,等于他到达目的地的时刻减去他来到出发地的时刻。因为只有一辆观光车,有时候还要停下来等其他乘客,乘客们纷纷抱怨旅行时间太长了。于是聪明的司机 ZZ 给公交车安装了 k k k 个氮气加速器,每使用一个加速器,可以使其中一个 D i − 1 D_i-1 Di​−1。对于同一个 D i D_i Di​ 可以重复使用加速器,但是必须保证使用后 D i ≥ 0 D_i\ge0 Di​≥0。

那么 ZZ 该如何安排使用加速器,才能使所有乘客的旅行时间总和最小?

输入格式

第 1 1 1 行是 3 3 3 个整数 n , m , k n,m,k n,m,k,每两个整数之间用一个空格隔开。分别表示景点数、乘客数和氮气加速器个数。

第 2 2 2 行是 n − 1 n-1 n−1 个整数,每两个整数之间用一个空格隔开,第 i i i 个数表示从第 i i i 个景点开往第 i + 1 i+1 i+1 个景点所需要的时间,即 D i D_i Di​。

第 3 3 3 行至 m + 2 m+2 m+2 行每行 3 3 3 个整数 T i , A i , B i T_i,A_i,B_i Ti​,Ai​,Bi​,每两个整数之间用一个空格隔开。第 i + 2 i+2 i+2 行表示第 i i i 位乘客来到出发景点的时刻,出发的景点编号和到达的景点编号。

输出格式

一个整数,表示最小的总旅行时间。

样例 #1

样例输入 #1

3 3 2
1 4
0 1 3
1 1 2
5 2 3

样例输出 #1

10

提示

【输入输出样例说明】

对 D 2 D_2 D2​ 使用 2 2 2 个加速器,从 2 2 2 号景点到 3 3 3 号景点时间变为 2 2 2 分钟。

公交车在第 1 1 1 分钟从 1 1 1 号景点出发,第 2 2 2 分钟到达 2 2 2 号景点,第 5 5 5 分钟从 2 2 2 号景点出发,第 7 7 7 分钟到达 3 3 3 号景点。

第 1 1 1 个旅客旅行时间 7 − 0 = 7 7-0=7 7−0=7 分钟。

第 2 2 2 个旅客旅行时间 2 − 1 = 1 2-1=1 2−1=1 分钟。

第 3 3 3 个旅客旅行时间 7 − 5 = 2 7-5=2 7−5=2 分钟。

总时间 7 + 1 + 2 = 10 7+1+2=10 7+1+2=10 分钟。

【数据范围】

对于 10 % 10\% 10% 的数据, k = 0 k=0 k=0。

对于 20 % 20\% 20% 的数据, k = 1 k=1 k=1。

对于 40 % 40\% 40% 的数据, 2 ≤ n ≤ 50 2 \le n \le 50 2≤n≤50, 1 ≤ m ≤ 1 0 3 1 \le m \le 10^3 1≤m≤103, 0 ≤ k ≤ 20 0 \le k \le 20 0≤k≤20, 0 ≤ D i ≤ 10 0 \le D_i \le 10 0≤Di​≤10, 0 ≤ T i ≤ 500 0 \le T_i \le 500 0≤Ti​≤500。

对于 60 % 60\% 60% 的数据, 1 ≤ n ≤ 100 1 \le n \le 100 1≤n≤100, 1 ≤ m ≤ 1 0 3 1 \le m \le 10^3 1≤m≤103, 0 ≤ k ≤ 100 0 \le k \le 100 0≤k≤100, 0 ≤ D i ≤ 100 0 \le D_i \le 100 0≤Di​≤100, 0 ≤ T i ≤ 1 0 4 0 \le T_i \le 10^4 0≤Ti​≤104。

对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 1 0 3 1 \le n \le 10^3 1≤n≤103, 1 ≤ m ≤ 1 0 4 1 \le m \le 10^4 1≤m≤104, 0 ≤ k ≤ 1 0 5 0 \le k \le 10^5 0≤k≤105, 0 ≤ D i ≤ 100 0 \le D_i \le 100 0≤Di​≤100, 0 ≤ T i ≤ 1 0 5 0 \le T_i \le 10^5 0≤Ti​≤105。


解题思路

首先我们来考虑 k = 0 k=0 k=0的情况,这时候t[i]为到第i个景点上车的乘客最晚的时间,last[i]为到车到达第i个景点的最小时间。

t[a[i]]=max(t[a[i]],T[i]); //T[i]为第i个乘客到达景点等车的时刻。

得到t可地推出last: last[i]=max(last[i-1],t[i-1])+d[i-1];

那么答案即为: ∑ i = 1 i = m l a s t [ b [ i ] ] − T [ i ] \sum_{i=1}^{i=m}last[b[i]]-T[i] ∑i=1i=m​last[b[i]]−T[i]
这时题目说可以缩短公交车的时间并且最多缩短K次,相当于可以贪心K次。
我们考虑缩短哪一段距离后,使得尽可能多的乘客旅行时间减一

如果我们在 i i i 到 i + 1 i + 1 i+1间使用加速器的话,那么在 i + 1 i + 1 i+1站下车的乘客的旅行时间都会减一,但是如果 l a s t [ i + 1 ] last[i + 1] last[i+1]小于 t [ i + 1 ] t[i + 1] t[i+1]的话,车就要在 i + 1 i + 1 i+1站等到所有的乘客上车,在 i + 1 i + 1 i+1站以后下车的乘客的时间是一样的,这个加速器对后面下车的乘客没有影响。我们可以用递推求出每个 i i i最远能影响的车站,用 f [ i ] f[i] f[i]表示,预处理求出在前i个车站中下车的总人数,用 s u m [ i ] sum[i] sum[i]表示

if(last[i+1]>t[i+1])f[i]=f[i+1];
else    f[i]=i+1;

枚举每个车站,取 s u m [ f [ i ] ] − s u m [ i ] sum[f[i]]-sum[i] sum[f[i]]−sum[i]的最大值,就是这次贪心减小的时间,对应试用加速器的道路时间-1.(注意道路时间不能为负)

每次贪心玩要重新计算一遍last,因为道路时间改变了。


代码

#include<bits/stdc++.h>
#define ll long long
using namespace std;int n,m,k,ans;
int a[10010],b[10010],T[10010],t[1010],f[1010],d[1010],sum[1010],last[1010];int main(){freopen("bus.in","r",stdin);freopen("bus.out","w",stdout);scanf("%d%d%d",&n,&m,&k);for(int i=1;i<n;i++){scanf("%d",&d[i]);}for(int i=1;i<=m;i++){scanf("%d%d%d",&T[i],&a[i],&b[i]);ans=ans-T[i];sum[b[i]]++;t[a[i]]=max(t[a[i]],T[i]);}for(int i=2;i<=n;i++){last[i]=max(last[i-1],t[i-1])+d[i-1];sum[i]+=sum[i-1];}for(int i=1;i<=m;i++)ans=ans+last[b[i]];while(k--){f[n-1]=f[n]=n;for(int i=n-2;i>0;i--){if(last[i+1]>t[i+1])f[i]=f[i+1];else f[i]=i+1;}int id=0,maxn=-1;bool ok=1;for(int i=1;i<n;i++){if(maxn<sum[f[i]]-sum[i]&&d[i]){maxn=sum[f[i]]-sum[i],id=i;ok=0;}}if(ok)break;ans=ans-maxn,d[id]--;for(int i=2;i<=n;i++)last[i]=max(last[i-1],t[i-1])+d[i-1];}printf("%d",ans);
}
/*
3 3 2
1 4
0 1 3
1 1 2
5 2 3*/

【洛古 P1315】 [NOIP2011 提高组] 观光公交相关推荐

  1. 【做题记录】[NOIP2011 提高组] 观光公交

    P1315 [NOIP2011 提高组] 观光公交 我们想在 \(k\) 次加速每一次都取当前最优的方案加速. 考虑怎样计算对于每一条边如果在当前情况下使用加速器能够使答案减少的大小. 如果当前到达某 ...

  2. 信息学奥赛一本通 1118:铺地毯 | 1863:【11NOIP提高组】铺地毯 | OpenJudge NOI 1.9 14 | 洛谷 P1003 [NOIP2011 提高组] 铺地毯

    [题目链接] ybt 1118:铺地毯 ybt 1863:[11NOIP提高组]铺地毯 OpenJudge NOI 1.9 14:铺地毯 洛谷 P1003 [NOIP2011 提高组] 铺地毯 [题目 ...

  3. 洛谷P1312 [NOIP2011 提高组] Mayan 游戏 题解

    题目描述 Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个7 行 5×5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游戏通关是指 ...

  4. 洛谷P1003 铺地毯 noip2011提高组day1T1

    洛谷P1003 铺地毯 noip2011提高组day1T1 洛谷原题 题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n ...

  5. c/c++ 洛谷 P1003 【NOIP2011 提高组】 铺地毯

    题目链接 洛谷 P1003 [NOIP2011 提高组] 铺地毯 不想戳的看下图: 样例及解释 数据范围 解题思路: 从后往前找地毯,找到了我就输出并返回. 代码如下: #include <io ...

  6. 信息学奥赛一本通 1844:【06NOIP提高组】金明的预算方案 | 洛谷 P1064 [NOIP2006 提高组] 金明的预算方案

    [题目链接] ybt 1844:[06NOIP提高组]金明的预算方案 洛谷 P1064 [NOIP2006 提高组] 金明的预算方案 [题目考点] 1. 动态规划:分组背包 2. 动态规划:依赖背包 ...

  7. 信息学奥赛一本通 1890:【15NOIP提高组】跳石头 | 洛谷 P2678 [NOIP2015 提高组] 跳石头

    [题目链接] ybt 1890:[15NOIP提高组]跳石头 洛谷 P2678 [NOIP2015 提高组] 跳石头 ybt 1247:河中跳房子 OpenJudge NOI 1.11 10:河中跳房 ...

  8. 信息学奥赛一本通 1848:【07NOIP提高组】字符串的展开 | OpenJudge NOI 1.7 35:字符串的展开 | 洛谷 P1098 [NOIP2007 提高组] 字符串的展开

    [题目链接] ybt 1848:[07NOIP提高组]字符串的展开 OpenJudge NOI 1.7 35:字符串的展开 洛谷 P1098 [NOIP2007 提高组] 字符串的展开 [题目考点] ...

  9. 信息学奥赛一本通 1855:【09NOIP提高组】潜伏者 | OpenJudge NOI 1.7 11:潜伏者 | 洛谷 P1071 [NOIP2009 提高组] 潜伏者

    [题目链接] ybt 1855:[09NOIP提高组]潜伏者 OpenJudge NOI 1.7 11:潜伏者 洛谷 P1071 [NOIP2009 提高组] 潜伏者 [题目考点] 1. 字符串 2. ...

最新文章

  1. java 匿名类调用方法_java – 从匿名类调用新定义的方法
  2. Dicom Test Files
  3. 编辑器推荐KindEditor
  4. C++Adaline自适应线性神经网络算法(附完整源码)
  5. ubuntu16 自启动mysql_Ubuntu16.04关闭apache/mysql/php的开机启动
  6. 内嵌Tomcat的Connector对象的静态代码块
  7. AVL树(Java实现)
  8. python连接postgis_python连接postgres方法
  9. Atitit ever note org log t99 目录 1. data 1 2. Sik dsk zip mode 1 3. Local exted stat 2 4. Recy 3 1
  10. 【未解决】【Linux环境】IDEA下搜狗输入法无法光标跟随
  11. 用计算机如何算行列式,数学计算器使用操作步骤
  12. 小白用Math对象随机生成一个名字
  13. android问号icon,CSS3 动态问号图标(使用工具生成)
  14. html中隐藏溢出怎么写,CSS溢出文字隐藏
  15. 软件测试系列——冒烟测试
  16. excel小写转大写公式_Excel办公技巧:快速将单元格中小写字母全部转换为大写字母...
  17. 企业降低包装成本的13种简单方法(下篇)
  18. hibernate之HQL属性查询
  19. 【问题解决】mac微信截图只能截到空白页面问题
  20. 90后美女的全能测试蜕变之路

热门文章

  1. 【POWERBI】GDP数据
  2. 下载中小学各个版本电子教材地址
  3. 离职后如何清空电脑账号资料
  4. 在windows中批量修改文件名
  5. excel--统计上大中小微企业划型判断工具
  6. 介绍两款在线数学公式编辑器
  7. iOS 无法添加 push notifications
  8. asa 防火墙拦截了https_防火墙(ASA)的基本配置与远程管理
  9. 使用统计学分析《鱿鱼游戏》中“玻璃垫脚石”的生存概率
  10. 从Excel中提取数据