結果
問題 |
No.1739 Princess vs. Dragoness (& AoE)
|
ユーザー |
👑 |
提出日時 | 2021-12-25 11:43:58 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 846 ms / 3,000 ms |
コード長 | 1,080 bytes |
コンパイル時間 | 882 ms |
コンパイル使用メモリ | 77,180 KB |
実行使用メモリ | 5,980 KB |
最終ジャッジ日時 | 2024-09-21 13:45:09 |
合計ジャッジ時間 | 15,215 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 40 |
ソースコード
#include <iostream> #include <vector> #include <algorithm> #include <queue> using namespace std; long long n,a,b,x,y; vector<long long> R; bool solve(long long ce){ int nwa = a; priority_queue<long long,vector<long long>> A; for(int i = 0; n > i; i++){ if(R[i]-ce > 0){ A.push(R[i]-ce); } } while(nwa){ if(A.size() == 0){ return true; } auto z = A.top();A.pop(); if(z > x){ A.push(z-x); } nwa--; } long long size = 0; while(A.size()){ auto z = A.top();A.pop(); size+=z; } if(size > b*y){ if(ce == 6)cout << size << " " << b*y << endl; return false; }else{ return true; } } int main(){ cin>>n>>a>>b>>x>>y; for(int i = 0; n > i; i++){ int t;cin>>t; R.push_back(t); } long long mn = -1; long long mx = 1000000000; while(abs(mn-mx) > 1){ long long ce = (mn+mx)/2; if(solve(ce)){ mx = ce; }else{ mn = ce; } } cout << mx << endl; }