結果
問題 |
No.2627 Unnatural Pitch
|
ユーザー |
![]() |
提出日時 | 2024-02-09 22:53:16 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 762 bytes |
コンパイル時間 | 2,962 ms |
コンパイル使用メモリ | 245,780 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-09-28 16:03:45 |
合計ジャッジ時間 | 7,589 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 8 WA * 15 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; int N, K; ll L, U, A[201010]; ll f(ll k){ if(k < 0)return 1e18; ll cnt = 0; for(int i = 0;i < N;i++){ if(A[i] < k){ cnt += (k - A[i] + K - 1) / K; } if(A[i] > k + U - L){ cnt += (A[i] - (k + U - L) + K - 1) / K; } } return cnt; } int main(void){ ios::sync_with_stdio(false); cin.tie(nullptr); cin >> N >> K >> L >> U; for(int i = 0;i < N;i++)cin >> A[i]; ll l = 0, r = 1e12; while(r - l > 2){ ll m1 = (l + l + r) / 3; ll m2 = (l + r + r) / 3; if(f(m1) >= f(m2))l = m1; else r = m2; } cout << min({f(l), f(l + 1), f(l + 2)}) << endl; return 0; }