博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[POI2013]Taksówki
阅读量:6834 次
发布时间:2019-06-26

本文共 1020 字,大约阅读时间需要 3 分钟。

[POI2013]Taksówki

题目大意:

ABC三地在同一条直线上,AC相距\(m(m\le10^{18})\)米,AB相距\(d\),B在AC之间。总共有\(n(n\le5\times10^5)\)辆车,每辆车只能从B地出发开\(x_i\)米(开完以后不必把车开回B地),问从A到C至少要坐几辆车?

思路:

对于BC之间的那一段路,如果可以走,则只要坐一辆车。对于AB之间的情况,只需要从大到小贪心即可。

\(x\)排序后,找到大于等于\(m-d\)的最小的\(x_i\),作为从B到C的车,剩下的车用来贪心。

时间复杂度\(\mathcal O(n\log n)\)

源代码:

#include
#include
#include
#include
typedef long long int64;inline int64 getint() { register char ch; while(!isdigit(ch=getchar())); register int64 x=ch^'0'; while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0'); return x;}const int N=5e5;int64 x[N];int main() { const int64 m=getint(),d=getint(); const int n=getint(); for(register int i=0;i
()); if(x[0]
=m-d;k++); int64 p; for(p=i=0;i
=d-p;i++) { if(i!=k) p+=x[i]-d+p; } if(i<=k) i++; if(p>=m) { printf("%d\n",i-1); return 0; } printf("%d\n",p+x[k]-std::max(d-p,0ll)>=m?i:0); return 0;}

转载于:https://www.cnblogs.com/skylee03/p/9603941.html

你可能感兴趣的文章
听到两个程序员聊天——A:“借我1K块。”
查看>>
Oracle ROWID
查看>>
重构可让SQL提高可维护性,可读性以及效能性
查看>>
java多线程例子
查看>>
fabric自动部署
查看>>
linux 命令小抄
查看>>
前端必读:浏览器内部工作原理
查看>>
C Socket Programming for Linux with a Server and Client Example Code
查看>>
6天通吃树结构—— 第一天 二叉查找树
查看>>
vs2005/vs2008和sql2005 的安装顺序
查看>>
powerdesigner 设置自动增长列(identity)和默认值
查看>>
Click Button to change the color of TextView
查看>>
oracle preparestmt 插入时间
查看>>
Java系的几种WebServer和ApplicationServer
查看>>
Android之菜单二——上下文菜单
查看>>
JavaScript中onmouseover时如何让鼠标指针变成一个小手状
查看>>
clear:both; 用法 什么时候用
查看>>
三层结构
查看>>
【简报】超棒的拖放式文件上传javascript类库:FileDrop
查看>>
连续子数组的最大和
查看>>