【26.83%】【Codeforces Round #380C】Road to Cinema
time limit per test1 second
memory limit per test256 megabytes
inputstandard input
outputstandard output
Vasya is currently at a car rental service, and he wants to reach cinema. The film he has bought a ticket for starts in t minutes. There is a straight road of length s from the service to the cinema. Let’s introduce a coordinate system so that the car rental service is at the point 0, and the cinema is at the point s.
There are k gas stations along the road, and at each of them you can fill a car with any amount of fuel for free! Consider that this operation doesn’t take any time, i.e. is carried out instantly.
There are n cars in the rental service, i-th of them is characterized with two integers ci and vi — the price of this car rent and the capacity of its fuel tank in liters. It’s not allowed to fuel a car with more fuel than its tank capacity vi. All cars are completely fueled at the car rental service.
Each of the cars can be driven in one of two speed modes: normal or accelerated. In the normal mode a car covers 1 kilometer in 2 minutes, and consumes 1 liter of fuel. In the accelerated mode a car covers 1 kilometer in 1 minutes, but consumes 2 liters of fuel. The driving mode can be changed at any moment and any number of times.
Your task is to choose a car with minimum price such that Vasya can reach the cinema before the show starts, i.e. not later than in t minutes. Assume that all cars are completely fueled initially.
Input
The first line contains four positive integers n, k, s and t (1 ≤ n ≤ 2·105, 1 ≤ k ≤ 2·105, 2 ≤ s ≤ 109, 1 ≤ t ≤ 2·109) — the number of cars at the car rental service, the number of gas stations along the road, the length of the road and the time in which the film starts.
Each of the next n lines contains two positive integers ci and vi (1 ≤ ci, vi ≤ 109) — the price of the i-th car and its fuel tank capacity.
The next line contains k distinct integers g1, g2, …, gk (1 ≤ gi ≤ s - 1) — the positions of the gas stations on the road in arbitrary order.
Output
Print the minimum rent price of an appropriate car, i.e. such car that Vasya will be able to reach the cinema before the film starts (not later than in t minutes). If there is no appropriate car, print -1.
Examples
input
3 1 8 10
10 8
5 7
11 9
3
output
10
input
2 2 10 18
10 4
20 6
5 3
output
20
Note
In the first sample, Vasya can reach the cinema in time using the first or the third cars, but it would be cheaper to choose the first one. Its price is equal to 10, and the capacity of its fuel tank is 8. Then Vasya can drive to the first gas station in the accelerated mode in 3 minutes, spending 6 liters of fuel. After that he can full the tank and cover 2 kilometers in the normal mode in 4 minutes, spending 2 liters of fuel. Finally, he drives in the accelerated mode covering the remaining 3 kilometers in 3 minutes and spending 6 liters of fuel.
【题目链接】:http://codeforces.com/contest/738/problem/C
【题解】
把每个gas station按照位置升序排;
把车按照v[i]升序排(c[i]不用管);
l = 1,r = n;
m = (l+r)>>1;
这个m作为当前枚举的车是什么;
注意到每次到车站之后油都能变满(哪个傻子不装满?免费的!)
它的容量作为从两个gas站之间的花费上限;
while(l<=r)
{
...
if (ok(m))
ans = m,r = m-1;
else
l = m+1;
}
那么ok函数要怎么写?
bool ok(int w)
{
LL temp =0;
for (i = 1->k)
{
int ds = p[i]-p[i-1];
if (ds*2<=w)//使用加速模式花费汽油是距离的两倍
temp+=ds;//所用的时间就是距离;
else//不能全部使用加速模式
{//那就设低速模式x分钟,加速模式y分钟
/*
则有
0.5*x+y=ds ···①距离要恰好为两个站之间的距离
0.5x+2*y<=w ···②花费的燃油要小于等于油箱容量
显然要让y最大,这样时间最短;
而联立①②式可得
y<=w-ds;
所以y的最大值为w-ds;
相应的x = 2*(ds-y);
*/
if (w-ds>0)//如果能够有一段为加速模式
{
y = w-ds;
x = 2*(ds-y);
cost = y*2+x/2;
temp+=(x+y);//时间就是x+y;
}
else//只能全程为低速模式尝试一下
{
if (ds<=w)
temp+=2*ds;//时间为两倍距离
else
return false;
}
}
if (temp>t)//时间大于t了就返回false;
return false;
}
return true;
}
这样我们就把油箱容量符合要求的最小油箱容量的车的下标ans搞出来了;
之后枚举1->n,找到那些油箱容量大于等于这个ans车的容量的车;在它们之间找价格最低的;
【完整代码】
#include <bits/stdc++.h>
#define LL long long
using namespace std;
const int MAXNK = 2e5+10;
const LL INF = 1e18;
struct abc
{
int c,v;
};
abc a[MAXNK];
int p[MAXNK];
int n,k,s;
LL t;
LL fi = INF;
bool cmp1(abc a,abc b)
{
return a.v < b.v;
}
bool ok(int w)
{
LL temp = 0;
for (int i = 1;i <= k;i++)
{
int cost = (p[i]-p[i-1])*2;
if (cost<=w)//直接全速前进
temp+=p[i]-p[i-1];
else
{//枚举在p[i-1]..p[i],前面用低速后面用高速;
int ds = p[i]-p[i-1];
int x,y;
if (w-ds>0)
{
y = w-ds;
x = 2*(ds-y);
cost = y*2+x/2;
temp+=(x+y);
/*
if (w==8)
{
puts("233");
cout << "ds==" << ds<<endl;
cout << "temp=="<<temp<<endl;
cout << "w-ds=="<<w-ds<<endl;
cout <<"cost=="<<cost<<endl;
cout << y<<endl;
cout << x<<endl;
}
*/
}
else
{
if (ds<=w)
temp+=2*ds;
else
return false;
}
}
if (temp > t)
return false;
}
return true;
}
int main()
{
//freopen("F:\\rush.txt","r",stdin);
cin >> n >> k >>s >>t;
for (int i = 1;i <= n;i++)
scanf("%d%d",&a[i].c,&a[i].v);
p[0] = 0;
for (int i = 1;i <= k;i++)
scanf("%d",&p[i]);
sort(a+1,a+1+n,cmp1);
sort(p+1,p+1+k);
k++;
p[k] = s;
/*
for (int i = 1;i <= k;i++)
cout << p[i] << " ";
cout << endl;
*/
int l = 1,r = n,ans = -1;
while (l <= r)
{
int m = (l+r)>>1;
if (ok(a[m].v))
{
ans = m;
r = m-1;
}
else
l = m+1;
}
if (ans == -1)
{
puts("-1");
return 0;
}
//cout << ans << endl;
for (int i = 1;i <= n;i++)
{
if (a[i].v >= a[ans].v && a[i].c < fi)
fi = a[i].c;
}
cout << fi << endl;
//wujie -1
return 0;
}
【26.83%】【Codeforces Round #380C】Road to Cinema的更多相关文章
- 【57.97%】【codeforces Round #380A】Interview with Oleg
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【42.86%】【Codeforces Round #380D】Sea Battle
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【21.21%】【codeforces round 382D】Taxes
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【50.88%】【Codeforces round 382B】Urbanization
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【Codeforces Round 1137】Codeforces #545 (Div. 1)
Codeforces Round 1137 这场比赛做了\(A\).\(B\),排名\(376\). 主要是\(A\)题做的时间又长又交了两次\(wa4\)的. 这两次错误的提交是因为我第一开始想的求 ...
- 【Codeforces Round 1132】Educational Round 61
Codeforces Round 1132 这场比赛做了\(A\).\(B\).\(C\).\(F\)四题,排名\(89\). \(A\)题\(wa\)了一次,少考虑了一种情况 \(D\)题最后做出来 ...
- 【Codeforces Round 1120】Technocup 2019 Final Round (Div. 1)
Codeforces Round 1120 这场比赛做了\(A\).\(C\)两题,排名\(73\). \(A\)题其实过的有点莫名其妙...就是我感觉好像能找到一个反例(现在发现我的算法是对的... ...
- 【Codeforces Round 1129】Alex Lopashev Thanks-Round (Div. 1)
Codeforces Round 1129 这场模拟比赛做了\(A1\).\(A2\).\(B\).\(C\),\(Div.1\)排名40. \(A\)题是道贪心,可以考虑每一个站点是分开来的,把目的 ...
- 【Codeforces Round 1117】Educational Round 60
Codeforces Round 1117 这场比赛做了\(A\).\(B\).\(C\).\(D\).\(E\),\(div.2\)排名\(31\),加上\(div.1\)排名\(64\). 主要是 ...
随机推荐
- C++ 补课 (三)
1,枚举类型 —— 下标自0开始 enum 枚举类型名 { 常数表 } 2,C++ 的异常处理机制实际上是一种运行时通知机制 3,delete p;只是删除指针p指向内存区,并不是删除指针p,所以p还 ...
- java 参数
-Xmx:size java最大堆内存 -Xms:size 初始化内存 -Xmn:size 年轻带堆大小 -XX:NewSize=size 年轻带的大小 -XX:NewRatio=ratio 年轻带和 ...
- 【Codeforces Round #457 (Div. 2) A】 Jamie and Alarm Snooze
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 暴力往前走x分钟就好. 直到出现7为止. [代码] #include <bits/stdc++.h> using nam ...
- TYVJ P1153 间谍网络
P1153 间谍网络 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 由于外国间谍的大量渗入,国家安全正处于高度危机之中.如果A间谍手中掌握着关于B间谍的犯罪 ...
- [leetcode] Palindrome Number(不使用额外空间)
本来推断回文串是一件非常easy的事情,仅仅须要反转字符串后在与原字符串相比較就可以.这道题目明白说明不能使用额外的空间.那么使用将其分解连接成字符串的方法便不是可行的.仅仅好採用数学的方式: 每次取 ...
- 经验之谈—让你看明确block
事实上我感觉不常常使用block的朋友.对block应该是比較陌生的,那么如今我们来扒开block的真面目,看看block的本质 普通的局部变量.block内部仅仅会引用它初始的值(block定义那一 ...
- [BZOJ2238]Mst 最小生成树+树链剖分/并查集
链接 题解 先构建出最小生成树,如果删的是非树边,直接输出答案 否则问题转化为,把该边删掉后剩下两个联通块,两个端点分别在两个块内的最小边权,LCT可以维护 不妨换一种思考方向:考虑一条非树边可以代替 ...
- Java经典23种设计模式之行为型模式(二)
本文接着介绍行为型模式里的解释器模式.迭代器模式.中介者模式. 一.解释器模式Interpret 给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言的中的句子. 1 ...
- windows下使用cpanm进行模块安装
windows下使用cpanm进行模块安装 要放假了,突然想整理一下手头上的软件,突然发现perl的安装模块这个功能不能用. 弄了一下,使得windows 下 perl 的 cpanm能用,避免成天为 ...
- mmx-编译脚本
脚本目录位置 /home/zhangshuli/git2/vanzo_team/xulei/Mmx.py 在-/bin目录下,链接Mmx.py ln -sf ~/git2/vanzo_team/xul ...