[NOIP2018PJ]摆渡车

luogu

mdPJ组这么难,还好考的TG组

先按t排序

设f[i][j]表示前i个人,第i个人等j分钟的最小总等待时间

这里j是小于2m的

可以考虑最坏情况下,一个人到起点时车刚好出发,m分钟之后回来

然后车又在起点停了m分钟等别人,则这个人一共等了2m分钟

转移分三种情况讨论:

下一个人赶上这趟车,即t[i+1]<=t[i]+j,那么转移到f[i+1][t[i]+j-t[i+1]]

下一个人在这趟车回来之前到了,即t[i+1]<=t[i]+j+m,枚举车回来后等待时间k,转移到f[i+1][t[i]+j+m-t[i+1]+k]

下一个人在这趟车回来之后才到,即t[i+1]>t[i]+j+m,直接枚举等待时间k,转移到f[i+1][k]

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int re(){
  4. int x=0,w=1;char ch=getchar();
  5. while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
  6. while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
  7. return x*w;
  8. }
  9. int n,m,ans,t[505],f[505][205];
  10. void Min(int&x,int y){x=min(x,y);}
  11. int main(){
  12. n=re(),m=re();
  13. for(int i=1;i<=n;i++)t[i]=re();
  14. sort(t+1,t+n+1);
  15. memset(f,63,sizeof(f));ans=f[0][0];
  16. for(int i=0;i<m*2;i++)f[1][i]=i;
  17. for(int i=1;i<n;i++){
  18. for(int j=0;j<m*2;j++){
  19. if(f[i][j]==ans)continue;
  20. if(t[i+1]<=t[i]+j)Min(f[i+1][t[i]+j-t[i+1]],f[i][j]+t[i]+j-t[i+1]);
  21. if(t[i+1]>t[i]+j+m){
  22. for(int k=0;k<m*2;k++)
  23. Min(f[i+1][k],f[i][j]+k);
  24. }
  25. else{
  26. for(int k=0;t[i]+j+m-t[i+1]+k<m*2;k++)
  27. Min(f[i+1][t[i]+j+m-t[i+1]+k],f[i][j]+t[i]+j+m-t[i+1]+k);
  28. }
  29. }
  30. }
  31. for(int i=0;i<m*2;i++)Min(ans,f[n][i]);
  32. printf("%d\n",ans);
  33. return 0;
  34. }

[NOIP2018PJ]摆渡车的更多相关文章

  1. 【LG5017】[NOIP2018pj]摆渡车

    [LG5017][NOIP2018pj]摆渡车 题面 洛谷 题解 震惊!普及组竟然考斜率优化??? 当然有其他的方法 首先我们转化一下模型 此题可以变为: 在一根时间轴上有一些点,每个时间点\(i\) ...

  2. [NOIP2018]摆渡车

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

  3. 【NOIP2018pj】题解

    [NOIP2018pj]题解 \(T1\) 题面 洛谷 题解 好像并没有什么好说的... #include <iostream> #include <cstdio> #incl ...

  4. 【LG5018】[NOIP2018pj]对称的二叉树

    [LG5018][NOIP2018pj]对称的二叉树 题面 洛谷 题解 看到这一题全都是用\(O(nlogn)\)的算法过的 考场上写\(O(n)\)算法的我很不开心 然后就发了此篇题解... 首先我 ...

  5. [NOIP2018PJ]对称二叉树

    [NOIP2018PJ]对称二叉树 这个题正常人看到题面难道不是哈希? 乱写了个树哈希... #include<bits/stdc++.h> using namespace std; co ...

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

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

  7. 『摆渡车 斜率优化dp及总结』

    摆渡车的题解我已经写过一遍了,在这里,这次主要从斜率优化的角度讲一下摆渡车,并总结一下斜率优化会出现的一些奇奇怪怪的错误. 摆渡车 Description 有 n 名同学要乘坐摆渡车从人大附中前往人民 ...

  8. [Noip 2018][标题统计 龙湖斗 摆渡车 对称二叉树]普及组题解

    啊喂,都已经9102年了,你还在想去年? 这里是一个Noip2018年PJ第二题打爆的OIer,错失省一 但经过了一年,我学到了很多,也有了很多朋友,水平也提高了很多,现在回看当时: 今年的Noip ...

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

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

随机推荐

  1. C语言学习笔记(二) 基础知识

    数据类型 C语言数据可以分为两大类: 基本类型数据和复合类型数据: 基本类型数据 整数 整型   (int)  ——占4字节 短整型(short int)  ——占2字节    长整型(long in ...

  2. Hyperlynx仿真学习

    转: 1.Hyperlynx 仿真模型讲解 2.Hyperlynx使用心得 3.https://blog.csdn.net/xyh627733894/article/details/78526725 ...

  3. 自己动手制作更好用的markdown编辑器-03

    这里文章都是从个人的github博客直接复制过来的,排版可能有点乱. 原始地址 http://benq.im/2015/04/24/hexomd-03/ 文章目录 1. 系统模块 2. 记录上次打开的 ...

  4. AF_UNIX和AF_INET域的socket在epoll中的差异

    1.AF_UNIX & SOCK_STREAM 1.1 accept_socket BLOCK EPOLLIN|EPOLLET 1.2 accept_socket NON-BLOCK EPOL ...

  5. Vue 组件5 高级异步组件

    自2.3.0起,异步组件的工厂函数也可以返回一个如下的对象. const AsyncComp = () => ({ // 需要加载的组件. 应当是一个 Promise component: im ...

  6. HibernateTools实现pojo类 数据库schma mapping映射的相互转换 二

    接着上一篇博客:HibernateTools实现pojo类 数据库schma mapping映射的相互转换 思路二:由数据库表,生成Mapping映射文件和POJO类. 尽管能够实现,但个人觉着先设计 ...

  7. 配置LANMP环境(1)-- 安装虚拟机VMware与安装CentOS7.2系统

    一.安装虚拟机VMware 1.下载VMware傻瓜式安装 2.配置                二.安装CentOS7.2系统 镜像下载链接 1.放入ios镜像文件之后,启动虚拟机,选择7.0+的 ...

  8. Mybatis+MSSql插入数据的同时并获取自增的ID

    在项目中遇到这样的情况,新增一个角色,这个角色有某些权限,这两个数据存在不同的表中,一个是sys_role,另外一个是sys_role_permission表,注意,现在的逻辑是这样的 1,在表sys ...

  9. php zend studio 如何导入已经存在的项目

    点击 左上的   file->import ->General->在选择第二个[  Exissting ....]

  10. Style Lessons in Clarity and Grace (11th Edition)中文翻译

    Joseph, Williams. "Style: Lessons in Clarity and Grace." Pearson Schweiz Ag (2014). 下载地址:h ...