题目链接:https://www.luogu.org/problemnew/show/P5017

emm,这次的真的不简单的,T3比T4难?

醉了。。。

蒟蒻肯定没有其他大佬讲的好啊,但肯定尽力,真的敲得呕心沥血,求过 。纪念写出的一道比较经典的线性动规。

分析题意,我(以弱者的角度先看问题) 首先想到的是:排序+贪心。本以为今天如此简单,结果发现是自己太天真了。。。然而之后发现:并不一定要一次接着一次的发车,所以贪心破产。

之后就有点摸不着头脑,去打了T4,出于宣泄直接上爆搜,惊奇的发现样例过了,赶快开心的回来再看T3.

这时候就想:普及深搜,模拟,签到都出了,这道题多半就是动规了吧,于是,扯了这么一大堆下面进入正题。

分析:

思路:动规+前缀和(但据某些大佬说还可以用斜率优化?在这里很抱歉我太弱而不会)。

首先我们直切核心——状态转移方程。

我们可以设f[i]f[i]f[i]表示i时间前所有人的最小等待时间。

PS:在这里如果不好确定方程的维数怎么办?可以结合数据范围和空间限制来考虑(多半是,虽然这题好像也可以有二维与t无关的数组)。

我们可以把每个人的时间都标在一条时间轴上。然后能更直观的理解。

这里借用@sooke 大佬的一张图。

我们假设发车时间为每个来回4min,各位等车的同学如图中蓝点所示。

然后我们假设当前要求的f[i]f[i]f[i]中的i=11i=11i=11,于是下面开始分析。

我们可以发现:如果之前的都已经算出的话,那么状态转移方程可如下所示:

f[i]=min(f[i],f[j]+(cnt[i]−cnt[j])∗i−(sum[i]−sum[j]));f[i]=min(f[i],f[j]+(cnt[i]-cnt[j])*i-(sum[i]-sum[j]));f[i]=min(f[i],f[j]+(cnt[i]−cnt[j])∗i−(sum[i]−sum[j]));

其中cnt[i]cnt[i]cnt[i]代表第i时间到达车站的同学的人数,sum[i]sum[i]sum[i]代表第i时间到达车站的同学的时间的总和。

jjj即为上一辆车的发车时间。

刚开始我们对于j的范围,应该能想到是:

0&lt;=j&lt;=i−m0&lt;=j&lt;=i-m0<=j<=i−m

很明显的( ⊙ o ⊙ )!j的取值只要小于i并且和i相聚一个往返时间不就行了吗?

然后的结果是:50分。(官方数据亲测)

但是noip都结束了呀同志,我们不能只局限于50分呀!

所以进行改进:

这时候我们又想:可不可以将j的范围进一步缩小呢?

但其实是肯定可以的。我们发现j可以:

i−2m+1&lt;=j&lt;=i−mi-2m+1&lt;=j&lt;=i-mi−2m+1<=j<=i−m

为什么呢?因为如果两车间的相距时间大于了一趟往返的时间,那么我们完全可以在两者中间继续分割,并不影响原来的答案。

这个时候也是大大的提升了程序的速度,然而:70分(官方数据亲测)

泪奔~

and then ,我们可以继续考虑有没有什么可以剪去的无用状态。

仔细研究发现:当两次发车之间如果没有需要等待的同学的话,直接跳过即可。

经过改正:100分(官方亲测)

AC代码:

#include<cstdio>
#include<cmath>
using namespace std;
int a[501],cnt[4000005],sum[4000005],f[4000005];
int main()
{
int n,m;
scanf("%d%d",&n,&m);
int Time=0;
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
cnt[a[i]]++;
sum[a[i]]+=a[i];
Time=fmax(Time,a[i]);
}
for(int i=1;i<Time+m;i++)
{
cnt[i]+=cnt[i-1];
sum[i]+=sum[i-1];
}
for(int i=0;i<Time+m;i++)
{
if (i>=m&&cnt[i-m]==cnt[i])
{
f[i]=f[i-m];
continue;
}
f[i]=cnt[i]*i-sum[i];
int tmp;
tmp=fmax(i-2*m+1,0);
for(int j=tmp;j<=i-m;j++)
{
f[i]=fmin(f[i],f[j]+(cnt[i]-cnt[j])*i-(sum[i]-sum[j]));
}
}
int ans=2147483647;
for(int i=Time;i<Time+m;i++)
{
ans=fmin(ans,f[i]);
}
printf("%d",ans);
return 0;
}
完结撒花~

NOIp2018普及组T3暨洛谷P5017 摆渡车:题解的更多相关文章

  1. NOIp2018 TG day1 T2暨洛谷P5020 货币系统:题解

    题目链接:https://www.luogu.org/problemnew/show/P5020 这道题感觉比较水啊,身为普及组蒟蒻都不费力的做出来了,而且数据范围应该还能大一些,n起码几万几十万都不 ...

  2. 洛谷 P5017 摆渡车

    题目传送门 解题思路: 个人感觉DP这东西,只可意会,不可言传 AC代码: #include<iostream> #include<cstdio> #include<cs ...

  3. NOIP2018&2013提高组T1暨洛谷P5019 铺设道路

    题目链接:https://www.luogu.org/problemnew/show/P5019 花絮:普及蒟蒻终于A了一道提高的题目?emm,写一篇题解纪念一下吧.求过! 分析: 这道题我们可以采用 ...

  4. Luogu 5017 NOIP2018普及组T3 摆渡车 (斜率优化 + 必要的转移进行剪枝)

    题意: 有 n 名同学要乘坐摆渡车从人大附中前往人民大学,第 i 位同学在第 ti​ 分钟去 等车.只有一辆摆渡车在工作,但摆渡车容量可以视为无限大.摆渡车从人大附中出发. 把车上的同学送到人民大学. ...

  5. 洛谷P5017摆渡车

    题目 一道做法多种多样的题,DP做法的状态也很多. 我用\(dp[i]\)表示在第i秒发车的时间和,然后dp方程就很好写了 \(dp[i] = dp[j] + i车的等待时间\)j属于i-2m ~ i ...

  6. P5017 [NOIP2018 普及组] 摆渡车

    P5017 [NOIP2018 普及组] 摆渡车 题目 P5017 思路 将实际问题抽象后,不难发现这是一个 区间 \(DP\) 我们不妨认为时间是一条数轴,每名同学按照到达时刻分别对应数轴上可能重合 ...

  7. NOIP2018普及组复赛游记

    2018年11月10日,NOIP2018普及组复赛. 这是我初中阶段最后一次复赛了. 和往常一样,我们在预定的早上7点,没有出发. 10分钟之后,人终于到齐了,于是出发了,一路无话. 到了南航,合照三 ...

  8. NOIP2018普及组初赛解题报告

    本蒟蒻参加了今年的NOIP2018普及组的初赛 感觉要凉 总而言之,今年的题要说完全没有难度倒也不至于,还有不少拼RP的题,比如第一次问题求解考逻辑推理,第一次完善程序考双链表等 下面我就和大家一起看 ...

  9. [NOIP2013 提高组] 华容道 P1979 洛谷

    [NOIP2013 提高组] 华容道 P1979 洛谷 强烈推荐,更好的阅读体验 经典题目:spfa+bfs+转化 题目大意: 给出一个01网格图,和点坐标x,y空格坐标a,b,目标位置tx,ty要求 ...

随机推荐

  1. oracle data guard备库备份恢复

    客户有套data guard环境,主库在阿里云上,备库在本地机房,现在想定期做备份,但是因为一些原因,备份阿里云上的主库实现会有些问题,所以只能备份本地的备库.目前需求就是测试备库的备份文件是否可以进 ...

  2. Twitter的分布式自增ID算法snowflake(雪花算法) - C#版

    概述 分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的.有些时候我们希望能使用一种简 ...

  3. 做个知识回顾目录,打算每日更新一下ios的基础知识

    一.基础技能列表:   01 面向对象特性       类与方法封装       通过继承扩展类       抽象类与方法覆盖       多态.动态类型和动态绑定       分类和协议       ...

  4. 用 jQuery.getJSON() 跨域请求 JSON 数据

    $.getJSON()可以理解为特殊形式的$.ajax(),手册里的说明好复杂,这里只记录一下用到的跨域请求. 先说在同一域名下,js发送数据到php,php返回JSON数据: $.getJSON(' ...

  5. Windows服务器下的IIS和Apache性能比较

    目前最流行的建立网站的服务工具就要属Apache与IIS了.那么他们之间到底哪个性能更好呢?到底哪个工具才是最适合我们的呢?最近我也对这方面的问题进行了一番研究. 如果是基于Linux平台的话,那不必 ...

  6. php 的mvc开发

    至于什么MVC结构,其实就是三个Model,Contraller,View单词的简称,,Model,主要任务就是把数据库或者其他文件系统的数据按 照我们需要的方式读取出来.View,主要负责页面的,把 ...

  7. kali 开启键盘背光灯 && 自定义开启终端

    新建文件保存扩展名为.sh 编辑文件,键入如下代码 #!/bin/bash - status=/tmp/keyboard_led_status if [[ ${1} == "on" ...

  8. MD5加密工具代码

    找到一个开源的MD5加密工具代码,收藏起来 /** * MD5加密工具 */ public class MD5Utils { /** * byte[]字节数组 转换成 十六进制字符串 * @param ...

  9. SqlServer导入大文件Sql

    sqlcmd -S "192.168.1.218" -U "sa" -P "1qaz~xsw2" -d "SispMain&quo ...

  10. T4生成实体和简单的CRUD操作

    主要跟大家交流下T4,我这里针对的是mysql,我本人比较喜欢用mysql,所以语法针对mysql,所以你要准备mysql的DLL了,同理sqlserver差不多,有兴趣可以自己写写,首先网上找了一个 ...