結果

問題 No.3509 Get More Money
コンテスト
ユーザー The Forsaking
提出日時 2026-04-18 11:36:35
言語 C++17
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++17 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
AC  
実行時間 148 ms / 2,000 ms
コード長 1,427 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,568 ms
コンパイル使用メモリ 216,248 KB
実行使用メモリ 18,532 KB
最終ジャッジ日時 2026-04-18 11:36:58
合計ジャッジ時間 22,079 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 60
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include <bits/stdc++.h>

using namespace std;

using pii = pair<int, int>;
using ll = long long;
const int N = 2000010, MOD = 998244353, INF = 0x3f3f3f3f;
int n, m, w[N];

ll k;
int a[N], b[N], c[N], d[N];
void solve() {
    scanf("%d%lld", &n, &k);
    for (int i = 1; i < n + 1; i++) scanf("%d", a + i);
    for (int i = 1; i < n + 1; i++) scanf("%d", b + i);
    for (int i = 1; i < n + 1; i++) scanf("%d", c + i);
    for (int i = 1; i < n + 1; i++) scanf("%d", d + i);
    multiset<pii> st;
    ll res = 0, sum = 0;
    for (int i = 1; i < n + 1; i++) {
        int p = d[i];
        st.insert({a[i], b[i]}), sum += b[i];
        while (d[i]) {
            if (st.size() && st.begin()->first < c[i]) {
                auto u = *st.begin();
                st.erase(st.begin());
                int t = min(d[i], u.second);
                d[i] -= t, u.second -= t, sum -= t;
                if (u.second) st.insert(u);
                res += (ll)(c[i] - u.first) * t;
            } else break;
        }
        if (p != d[i]) st.insert({c[i], p - d[i]}), sum += p - d[i];
        while (sum > k) {
            auto u = *st.rbegin();
            st.erase(st.find(u));
            int g = min(sum - k, (ll)u.second);
            u.second -= g, sum -= g;
            if (u.second) st.insert(u);
        }
    }
    printf("%lld\n", res);
}

int main() {
    int T = 1;
    cin >> T;
    while (T--) solve();
    return 0;
}
0