ACDREAM 03G ACdream的高速公路(贪心专场)

ACDREAM 03G ACdream的高速公路

Problem Description

ACdream王国有一条贯穿整个王国的高速公路,一天,你要驾驶着一辆油箱容量为P的车从高速公路的一头驶向另一头,总路程为L千米,每单位体积的汽油可维持行驶W千米,显然路途遥远~总有不够油的情况,所以就要加油~!

再高速公路上总共有N个加油站,但是由于是不同人开的,因此定价也参差不齐。

现在你知道每个加油站的位置,以及每个加油站的单价,问你最少需要多少钱才能到达另一头?
Input

多组数据,每组数据首先是四个整数,P(1<=P<=100),L(1<=L<=30000),W(1<=W<=20),N(1<=N<=500),分别代表油箱容量,路程,每单位体积的路程,加油站数目。

接下来是N行,每行包括一个精确到百分位的实数X(9

解题思路:将0到L每一米都更新成最便宜的油价,然后走一遍之后,除以w,就是最优的油价。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cstdlib>
using namespace std;
const double INF = 0x3f3f3f3f;
typedef long long ll;
int R;
double vis[30005];
struct oilStation{
    double m;
    int p;
}os[505];
int cmp(oilStation a, oilStation b) {
    return a.p < b.p;
}
void REC(int pos, double m) {
    for (int i = pos + 1; i <= pos + R; i++) {
        if (vis[i] > m) vis[i] = m;
    }
}
int main() {
    int p, l, w, n;
    while (scanf("%d %d %d %d", &p, &l, &w, &n) == 4) {
        for (int i = 0; i <= l + 1; i++) {
            vis[i] = INF;
        }
        R = p * w;
        for (int i = 0; i < n; i++) {
            scanf("%lf %d", &os[i].m, &os[i].p);
        }
        sort(os, os + n, cmp);
        for (int i = 0; i < n; i++) REC(os[i].p, os[i].m);
        double sum = 0;
        int flag = 1, pos;
        for (int i = 1; i <= l; i++) {
            if (fabs(vis[i] - INF) < 1e-9) {
                flag = 0;
                pos = i;
                break;
            }
            sum += vis[i];
        }
        if (flag) printf("YES\n%.2lf\n", sum * (1.0) / w);
        else printf("NO\n%.2f\n", (pos - 1) * 1.0);
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值