ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

[USACO2005OPEN]Expedition

2022-01-03 22:31:34  阅读:123  来源: 互联网

标签:队列 Expedition int scanf jyz 加油站 USACO2005OPEN wz


贪心+堆/优先队列

如果现在的油量能到达下一个加油站则继续走;否则就要加上之前走过的加油站中油最多没走过的加油站的油,如果前面的所有加油站都加过油了还不能到达下一个加油站输出 -1。

看到要求最大值,第一想到的肯定是 sort。但是!sort 被卡了。

那怎么办呢?这样一来,就想到了堆和优先队列。

#include <bits/stdc++.h>
using namespace std;
struct jyz {
    int wz, yl;
    bool operator<(const jyz& other) const
    {
        return yl < other.yl;
    }//重载运算符,比sort排序还快些
} s[10010];
priority_queue<jyz> q;
int cmp2(jyz x, jyz y)
{
    return x.wz < y.wz;
}
int main()
{
    int n, y, t = 0, x;
    scanf("%d", &n);
    for (int i = n; i >= 1; i--) {
        scanf("%d%d", &s[i].wz, &s[i].yl);
    }//这里倒序不用管
    scanf("%d%d", &x, &y);
    for (int i = 1; i <= n; i++) {
        s[i].wz = x - s[i].wz;
    }//算出离起点的距离
    s[n + 1].wz = x, s[n + 1].yl = 0;//记得算上终点
    sort(s + 1, s + 1 + (n + 1), cmp2);//输入可能是无序的,所以要排个序
    for (int i = 1; i <= n + 1; i++) {
        if (y < s[i].wz) {//到不了
            if (t == i - 1) {
                printf("-1");//前面的都加过了
                return 0;
            }
            while (y < s[i].wz) {
                if (t == i - 1) {
                    printf("-1");
                    return 0;
                }
                jyz p = q.top();
                t++;
                y += p.yl;
                q.pop();
            }//一直加到可以到达
        }
        q.push((jyz){ s[i].wz, s[i].yl });
    }
    printf("%d", t);
}

我这里用的是优先队列,如果不嫌麻烦也可以用堆来做。

标签:队列,Expedition,int,scanf,jyz,加油站,USACO2005OPEN,wz
来源: https://blog.csdn.net/weixin_62672940/article/details/122293510

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有