結果

問題 No.3459 Defeat Slimes
コンテスト
ユーザー GOTKAKO
提出日時 2026-03-01 22:48:43
言語 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  
実行時間 86 ms / 3,000 ms
コード長 1,424 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 5,419 ms
コンパイル使用メモリ 226,940 KB
実行使用メモリ 16,376 KB
最終ジャッジ日時 2026-03-01 22:48:57
合計ジャッジ時間 6,337 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include <bits/stdc++.h>
using namespace std;

int main(){
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);

    long long N,Y,Z; cin >> N >> Y >> Z;
    priority_queue<tuple<long long,long long,long long>,vector<tuple<long long,long long,long long>>,greater<>> Q2;
    priority_queue<pair<long long,long long>> Q;
    while(N--){
        long long a,b,c; cin >> a >> b >> c;
        Q2.push({b,c,a});
    }
    while(Q2.size()){
        auto [L,X,C] = Q2.top();
        if(L <= Y) Q2.pop(),Q.push({X,C});
        else break;
    }
    long long answer = 0;
    while(Q.size() && Y < Z){
        auto [X,C] = Q.top(); Q.pop();
        if(Q2.size()){
            auto [l,x,c] = Q2.top();
            if(Z <= l){
                long long use = min(C,(Z-Y+X-1)/X);
                answer += use,Y += use*X;
                if(use != C) Q.push({X,C-use}); 
            }
            else{
                long long use = min(C,(l-Y+X-1)/X);
                answer += use,Y += use*X;
                if(use != C) Q.push({X,C-use});
            }
        }
        else{
            long long use = min(C,(Z-Y+X-1)/X);
            answer += use,Y += use*X;
            if(use != C) Q.push({X,C-use});
        }
        while(Q2.size()){
            auto [l,x,c] = Q2.top();
            if(Y >= l) Q2.pop(),Q.push({x,c});
            else break;
        }
    }
    if(Y < Z) answer = -1;
    cout << answer << endl;

}
0