Codeforces-738C

题目简介

这道题给我们n两汽车,每辆汽车有所需要的价钱c与其油箱的最大存油量v,然后给我们一段路程s,其中有k个加油站,问是否能在t时间内跑完这段路程。所有汽车均有两种运行模式:
1.普通模式:1km 用 2min 用 1L 油。
2.加速模式:1km 用 1min 用 2L 油。
如果能跑完则输出最少需要花费的租车费。
如果全都没办法跑完全程则输出-1。
(二分+贪心)

样例输入

3 1 8 10
10 8
5 7
11 9
3

样例输出

10

解题思路

1.用结构体储存汽车数据,并将汽车数据按照油箱大小从小到大排序。
2.计算每段加油站之间的距离。(ps : 加油站的位置不一定是顺序给出的 , 需要排序)
3.首先判断油箱最大的汽车是否能在规定时间内跑到终点,若不能直接输出-1。
4.若油箱最大的汽车能跑完全程则用二分法找出能跑完全程的最小油箱量。然后再在最小油箱量和最大油箱的汽车数据之间选出需要花费钱最小的那一个。

关于如何判断是否满足条件:
本题只有三种情况。(按照每一段距离来计算时间,记油箱容量为x,若时间小于规定时间则成立)
1.distance > x ,则中途没油。
2.distance * 2 <= x , time += distance 。在这段距离内能全速跑。
3.distance < x < distance2 , time += (3distance - x) 。 尽量加速跑。

数据较大,最好用long long。
(ps : 因为我比较菜所以几乎所有东西都改成了long long )

代码如下

#include<cstdio>
#include<algorithm>
#define LL long long
using namespace std;
const int maxn = 200050;

LL con = 0;      // 计算有多少段距离;
LL sta[maxn];     // 开一个加油站位置的数组;
LL dis[maxn];     // 每两个加油站之间距离的数组;
LL  n,k,s,t;      // n代表汽车数量,k代表加油站数量,s为路程,t为最大时间;
struct car
{
    LL c,v;      // 包含车子的数据,c为价钱,v为最大油量;
} cars[maxn];

bool cmp(car a,car b)       // 让车子数据按照油量从小到大进行排序;
{
    if(a.v != b.v) return a.v < b.v;
}

bool judge(LL x)
{
    LL time = 0;

    for(int i = 0 ; i < con ; i++)
    {
        if(dis[i] > x) return false ;// 若距长于最大油量则不可能通过;
        if(2*dis[i] <= x) time += dis[i];
        else time += (3*dis[i] - x);
    }
    if(time > t) return false;
    return true;
}

int main()
{
    scanf("%lld%lld%lld%lld",&n,&k,&s,&t);
    for(int i = 1 ; i <= n ; i++)                // 从1到n读取汽车的数据;
        scanf("%lld%lld",&cars[i].c,&cars[i].v);
    sta[0]=0;
    for(int i = 1 ; i <= k ; i++)          // 从1到n读取加油站的位置;
        scanf("%lld",&sta[i]);
    sta[k+1]=s;
    sort(sta,sta+k+1);  // 将加油站的位置按从小到大排序;
    for(int i = 1 ; i <= k+1 ; i++)   // 储存每段距离;
    {
        dis[con]=sta[i]-sta[i-1];
        con++;
    }
    sort(cars+1,cars+1+n,cmp);  // 讲1到n号车按油量从小到大排序;
    if(!judge(cars[n].v)) printf("-1\n");  //若最大油量不可能跑到终点则输出-1;
    else                                 // 二分查找满足条件的最小油量;
    {
        LL l = 1;
        LL r = n;
        LL goal = n;
        while(l <= r)
        {
            LL mid = (l + r)/2;
            if(judge(cars[mid].v))
            {
                r = mid - 1;
                goal = mid;
            }
            else l = mid + 1;
        }

        LL minn = 1000000005;
        for(int i = goal ; i <= n ; i++)
        {
            if(cars[i].c <= minn) minn = cars[i].c;
        }
        printf("%lld\n",minn);
    }

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,740评论 0 33
  • 贪心算法 贪心算法总是作出在当前看来最好的选择。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上...
    fredal阅读 9,223评论 3 52
  • 〇、引言 大家好,我是无涯,来自广西柳州,目前在北京就职于一家亚洲最大的上市汽车租赁公司,从事营销广告工作,其实呢...
    I无涯阅读 1,192评论 0 49
  • 我叫木村翔,我是一名拳击手。 01 虽然我是职业的拳击手,可是拳击并不能给我带来一份体面的收入,甚至不能保障我基本...
    六一说阅读 308评论 1 1
  • 1 2017年9月3日小犟龟班进入了开学时期。 2我完成的假期所有的作业,还进行了一项特殊的比赛,钢琴比赛。 3这...
    张忠楷阅读 134评论 0 1