• 【Codeforces 738C】Road to Cinema


    http://codeforces.com/contest/738/problem/C

    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 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 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, speding 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.

    题意:n个价格c[i],油量v[i]的汽车,求最便宜的一辆使得能在t时间内到达s,路途中有k个位置在g[i]的加油站,可以免费加满油,且不耗时间。每辆车有两种运行模式可以随时切换:1.每米一分钟两升油;2.每米两分钟一升油。

    题解:二分求可以到达s的最小油量。对于油量v,能到达s的条件是:油量足够经过最长路程(中途不能加油);总的最小时间不超过t。为了求最小时间,可以用线性规划:一段不加油的路程长度为l,假设x米运行的是1.模式,则l-x米运行的是2.模式。总时间为t。则有

    egin{equation}
    left{
    egin{aligned}
    t=x+2*(l-x)\
    v≥x*2+l-x\
    x≥0\
    l-x≥0\
    end{aligned}
    ight.
    end{equation} 

    化简一下:

    egin{equation}
    left{
    egin{aligned}
    t=2*l-x\
    x≤v-l\
    l≥x≥0\
    end{aligned}
    ight.
    end{equation}

    最后得到:

    egin{aligned}
    t_{min} & = 2*l-x_{max}\
    & = 2*l-min(v-l,l)\
    & = max(l*3-v,l)\
    end{aligned}

    且v≥l,可以改为v≥max(l)。

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #define ll long long
    #define N 200005
    using  namespace std;
    int n,k,s,t,c[N],v[N],g[N],mg,ans=1e9+1,mv;
    bool ck(int v){
        if(v<mg)return 0;
        int tol=0;
        for(int i=1;i<=k+1;i++){
            tol+=max(g[i],3*g[i]-v);
            if(tol>t)return 0;
        }
        return 1;
    }
    int main(){
        scanf("%d%d%d%d",&n,&k,&s,&t);
        for(int i=1;i<=n;i++)
            scanf("%d%d",c+i,v+i);
        for(int i=1;i<=k;i++)
            scanf("%d",g+i);
        sort(g+1,g+1+k);
        g[k+1]=s;
        for(int i=k+1;i;i--)
            mg=max(mg,g[i]-=g[i-1]);
    //接下来是萌萌哒的二分
        for(int l=0,r=1e9,m=l+r>>1;l<=r;ck(m=l+r>>1)?r=m-1,mv=m:l=m+1);
        if(mv)
        for(int i=1;i<=n;i++)if(v[i]>=mv) ans=min(ans,c[i]);
        if(ans>1e9)ans=-1;
        printf("%d",ans);
        return 0;
    }

      

  • 相关阅读:
    WMI远程添加修改用户
    C#中利用mediaplayer打造mp3播放器
    使用BackgroundWorker 实现文件下载、异步提示
    asp.net 修改图片的分辨率,修改图片的长宽象素比例,修改图片的物理宽度大小
    修改注册表,让组策略对管理员无效
    一款支持CHM格式的安卓阅读器:ireader
    一款超好用的PDF阅读器:智器阅读
    C#基础温习(8):命名空间介绍
    书籍推荐:《职场潜伏心理学:全世界最权威的88个心理学定律》
    C#基础温习(10):C#实现托盘功能
  • 原文地址:https://www.cnblogs.com/flipped/p/6083973.html
Copyright © 2020-2023  润新知