zoukankan      html  css  js  c++  java
  • Codeforces #380 div2 C(729C) Road to Cinema

    C. Road to Cinema
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard 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 point0, 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 2minutes, 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 tminutes. Assume that all cars are completely fueled initially.

    Input

    The first line contains four positive integers nks 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 3minutes, 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.

     题目大意:一个一维的路,从距离为0到距离为s,中间有一些加油站,每次都能不耗时加满油,每辆车有c和v,分别表示租金和油量,有两种速度,一公里花1个单位时间消耗2个单位的油,一公里花2个单位的时间花1个单位的油,要求在t秒内到达终点所能租的最便宜的车花多少钱?

    做法:稍微思考就能看出是二分,由于每次路过加油站都能加满油而且不耗时,所以争取在能到达下一个加油站(或终点)的前提条件下能开多快开多快,所以如果△s>v,那么v太小了不行,如果△s小于0.5v,那么耗时△t=s,其他情况,计算得△t=3s-v,将每一个△t加起来,判断是否小于等于t。

    因此对每一个v都可判断t秒内能不能走到终点,对t取值进行二分,找到满足条件的最小的v,用这个v遍历汽车油量与租金,在满足油量>v的基础上找最小租金。

    PS:除了几处手残写错之外,注意加油站的位置不是按顺序给的,所以要排个序。。。本来觉得这道题肯定能做出来,最后剩下2分钟过的,好险。

    代码:

     1 #include <cstdio>
     2 #include <ctime>
     3 #include <cstdlib>
     4 #include <iostream>
     5 #include <cstring>
     6 #include <cmath>
     7 #include <queue>
     8 #include <algorithm>
     9 #define N 200005
    10 #define inf 1e18+5
    11 typedef long long ll;
    12 #define rep(i,n) for(i=0;i<n;i++)
    13 using namespace std;
    14 ll k,m,n,t,cc,s,ma,mi;
    15 ll g[N];
    16 struct st{
    17     ll c;
    18     ll v;
    19 }a[N];
    20 bool check(ll v);
    21 int  main()
    22 {
    23     while(scanf("%lld%lld%lld%lld",&n,&k,&s,&t)!=EOF){
    24         ma=-1;
    25         mi=inf;
    26         for(int i=1;i<=n;i++){
    27         scanf("%lld %lld",&a[i].c,&a[i].v);
    28         ma=max(ma,a[i].v);
    29         mi=min(mi,a[i].v);
    30         }
    31         for(int i=1;i<=k;i++){
    32             scanf("%lld",&g[i]);
    33         }
    34         sort(g+1,g+k+1);
    35         ll l=mi,r=ma;
    36         while(l<r-1){
    37             ll mid=(l+r)>>1;
    38             if(check(mid)==1){
    39                 r=mid;
    40             }
    41             else {
    42                 l=mid;
    43             }
    44         }
    45         ll ans=0;
    46         if(check(l)) ans=l;
    47         else if(check(r)) ans=r;
    48         else ans=inf;
    49         ll aa=inf;
    50         for(int i=1;i<=n;i++){
    51             if(a[i].v>=ans){
    52                 aa=min(aa,a[i].c);
    53             }
    54         }
    55         if(aa==inf) printf("-1\n");
    56         else printf("%lld\n",aa);
    57     }
    58     
    59     return 0;
    60 }
    61 bool check(ll v){
    62     
    63     ll t1=0;
    64     ll s1=g[1];
    65         if(s1>v) {
    66             return 0;
    67         }
    68         else if(s1<=v&&s1>=(v/2.0)){
    69             t1+=3*s1-v;
    70         }
    71         else {
    72             t1+=s1;
    73         }
    74     for(int i=1;i<k;i++){
    75         ll s1=g[i+1]-g[i];
    76         if(s1>v) {
    77             return 0;
    78         }
    79         else if(s1<=v&&s1>=(v/2.0)){
    80             t1+=3*s1-v;
    81         }
    82         else {
    83             t1+=s1;
    84         }
    85     }
    86     s1=s-g[k];
    87     if(s1>v) {
    88             return 0;
    89         }
    90         else if(s1<=v&&s1>=(v/2.0)){
    91             t1+=3*s1-v;
    92         }
    93         else {
    94             t1+=s1;
    95         }
    96     if(t1>t) return 0;
    97     else return 1;
    98 }
  • 相关阅读:
    20135315宋宸宁信息安全系统设计基础期末总结
    信息安全系统设计基础第十四周学习总结
    树莓派之web服务器搭建
    读书笔记——《图解TCP/IP》(2/4)
    信息安全系统设计基础第十三周学习总结
    读书笔记——《图解TCP/IP》(1/4)
    读书笔记——《暗时间》汇总
    信息安全系统设计基础第十二周学习总结
    20135315 宋宸宁 、20135333 苏正生——实验3
    读书笔记——《暗时间》(2/2)
  • 原文地址:https://www.cnblogs.com/Crazycatmiao/p/6091439.html
Copyright © 2011-2022 走看看