标签:false 二分 plain highlight represent can alt 便宜 cti
1.给你n辆车,k个加油站,s路程,t秒内到达
2.所有车都有两种mode:1km / min 和 1km / 2min,耗油量是 2/km 和 1/km
3.每辆车有价格和油罐容量,路过加油站汽油可瞬间满血。求最便宜的车。
1.写一个bool函数judge,用来判断车花费最少时间mint,如果mint<=t返回真。用加油站把路程分组,每组求出mint,累加起来。
2.每组路程dis有三种情况:
A.油罐容量feul<dis,说明用慢速都到大不了,return false;
B.油罐容量fuel>=2*dis,说明直接用高速到达即可,速度是1km/min,所以mint+=dis;
C. 油罐容量介于AB之间,尽可能用高速。设高速行驶x km,低速行驶y km。
则有x+y=dis,2x+y<=feul。
得出x<=fuel-dis,即x的最大值为fuel-dis。mint+=x+2*y。
3.用车中的最大油罐量maxfuel走一次judge,如果不行直接输出-1。否则二分(0,maxfuel)求出能准时到达的最小油罐容量。
4.最后扫一遍车,如果车的容量大于最小容量,则res=min(res,car[i].cost);
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 | #include<iostream>#include<algorithm>#include<cstdio>usingnamespacestd;constintmaxn=200200;structCar{    intcost, fuel;}car[maxn];intgas[maxn];booljudge(intfuel,intk,intt){    /*        x+y=dis        2x+y<=fuel        so x<=fuel-dis        x represent the distance with high speed, y ...    */    inti,j;    intmint=0;    for(i=1;i<=k+1;i++)    {        intdis=gas[i]-gas[i-1];        if(fuel<dis)            returnfalse;        elseif(fuel>=2*dis)            mint+=dis;        else        {            intx=fuel-dis;            inty=dis-x;            mint+=x+2*y;        }    }    returnmint<=t;}intmain(){    intn,k,s,t,i,j;    scanf("%d%d%d%d",&n,&k,&s,&t);    intmaxfuel=-1;    for(i=1;i<=n;i++)        scanf("%d%d",&car[i].cost,&car[i].fuel),        maxfuel=max(maxfuel,car[i].fuel);    for(i=1;i<=k;i++)        scanf("%d",&gas[i]);    sort(gas+1,gas+k+1);    gas[0]=0;    gas[k+1]=s;    if(!judge(maxfuel,k,t))    {        printf("-1\n");        return0;    }    intlow,high;    low=0,high=maxfuel;    while(low<high)    {        intmid=low+high >> 1;        if(judge(mid,k,t))            high=mid;        else            low=mid+1;    }    intres=2e9+5;    for(i=1;i<=n;i++)        if(car[i].fuel>=low)            res=min(res,car[i].cost);    printf("%d\n",res);}    | 
Codeforces Round #380 (Div. 2) C. Road to Cinema 二分
标签:false 二分 plain highlight represent can alt 便宜 cti
原文地址:http://www.cnblogs.com/zehong1995/p/6091240.html