4665: 【GESP2412六级】运送物资

内存限制:128 MB 时间限制:1.000 S
评测方式:文本比较 命题人:
提交:2 解决:1

题目描述

$m$ 辆货车,每辆货车每天需要向 A 市和 B 市运送若干次物资。小杨同时拥有$n$ 个运输站点,这些站点位于 A 市和 B 市之间。
每次运送物资时,货车从初始运输站点出发,前往 A 市或 B 市,之后返回初始运输站点。A 市、B 市和运输站点的位置可以视作数轴上的三个点,其中 A 市的坐标为$0$ ,B 市的坐标为$x$ ,运输站点的坐标为$p$ 且有$0< p < x$ ,货车每次去 A 市运送物资的总行驶路程为 $2p$,去 B 市运送物资的总行驶路程为$2(x-p)$ 。
对于第$i$ 个运输站点,其位置为$p_i$ 且至多作为$c_i$ 辆车的初始运输站点。小杨想知道,在最优分配每辆货车的初始运输站点的情况下,所有货车每天的最短总行驶路程是多少。

输入

第一行包含三个正整数$n,m,x$ ,代表运输站点数量,货车数量和两市距离。
之后$n$ 行,每行包含两个正整数$p_i,c_i$ ,代表第$i$ 个运输站点的位置和最多容纳车辆数。
之后$m$ 行,每行包含两个正整数$a_i,b_i$ ,代表第$i$ 辆货车每天需要向 A 市运送$a_i$ 次物资,向 B 市运送$b_i$ 次物资。

输出

输出一个正整数,代表所有货车每天的最短总行驶路程。

样例输入 复制

3 4 10
1 1
2 1
8 3
5 3
7 2
9 0
1 10000

样例输出 复制

40186

提示

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int N = 1e5 + 10;
int n, m;
ll x;
vector < pair < int, int > > st;
int a[N], b[N];
int main() {
    cin >> n >> m >> x;
    for (int i = 1; i <= n; i++) {
        int p, c;
        cin >> p >> c;
        st.push_back(make_pair(p, c));
    }
    sort(st.begin(), st.end());
    for (int i = 1; i <= m; i++) {
        cin >> a[i] >> b[i];
    }
    vector < pair < int, int > > neg, pos;
    ll res = 0;
    for (int i = 1; i <= m; i++) {
        if (a[i] >= b[i])
            pos.push_back(make_pair(a[i] - b[i], i));
        else {
            neg.push_back(make_pair(a[i] - b[i], i));
        }
        res += 1ll * b[i] * x;
    }
    sort(neg.begin(), neg.end());
    sort(pos.begin(), pos.end());
    reverse(pos.begin(), pos.end());
    int l = 0, r = n - 1;
    for (auto i: neg) {
        while (r >= 1 && st[r].second == 0) r--;
        res += 1ll * (a[i.second] - b[i.second]) * st[r].first;
        st[r].second -= 1;
    }
    for (auto i: pos) {
        while (l <= n && st[l].second == 0) l++;
        res += 1ll * (a[i.second] - b[i.second]) * st[l].first;
        st[l].second -= 1;
    }
    cout << res * 2 << "\n";
}