結果
問題 | 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;}