結果
問題 | No.1071 ベホマラー |
ユーザー |
![]() |
提出日時 | 2020-06-05 23:20:12 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 21 ms / 2,000 ms |
コード長 | 719 bytes |
コンパイル時間 | 1,315 ms |
コンパイル使用メモリ | 164,620 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-12-17 18:17:04 |
合計ジャッジ時間 | 2,484 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 20 |
ソースコード
#include <bits/stdc++.h> using namespace std; #define int long long const int MOD = 1000000007; int mul(int a, int b) { double x = (double)a * (double)b; if (x > 3e18) { return 2e18 + 5; } return a * b; } signed main() { cin.tie(0); ios::sync_with_stdio(false); int N, K, X, Y; cin >> N >> K >> X >> Y; vector<int> A(N); int sum = 0; for (int i = 0; i < N; i++) { cin >> A[i]; A[i] = (A[i] - 1 + K - 1) / K; sum += A[i]; } sort(A.begin(), A.end()); int res = (int)1 << 62; int l = 0; int c = 0; res = res, A.back() * Y; res = min(res, mul(sum, X)); for (int i = 0; i < N; i++) { sum -= (A[i] - l) * (N - i); res = min(res, mul(sum, X) + A[i] * Y); l = A[i]; } cout << res << endl; }