結果
| 問題 |
No.1440 The Quiz Competition
|
| コンテスト | |
| ユーザー |
ocvret_
|
| 提出日時 | 2021-03-26 23:08:06 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 2,288 bytes |
| コンパイル時間 | 1,768 ms |
| コンパイル使用メモリ | 168,972 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-11-29 01:19:51 |
| 合計ジャッジ時間 | 2,690 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 2 WA * 25 |
ソースコード
#include<bits/stdc++.h>
// #include<atcoder/all>
// #include<boost/multiprecision/cpp_int.hpp>
using namespace std;
// using namespace atcoder;
// using bint = boost::multiprecision::cpp_int;
using ll = long long;
using ull = unsigned long long;
using P = pair<int,int>;
#define rep(i,n) for(ll i = 0;i < (ll)n;i++)
#define ALL(x) (x).begin(),(x).end()
#define MOD 1000000007
int main(){
int T;
cin >> T;
while(T--){
ll n,A,W,K;
cin >> n >> A >> W >> K;
if(K != n && K != 1){
__int128_t l = -1,r = MOD;
while(r-l > 1){
__int128_t mid = (l+r)/2;
bool ok = true;
if((mid+1)*(K-1) + mid > A)ok = false;
if(ok)l = mid;
else r = mid;
}
if(l == -1){
if(W >= n - K + 1)l = -1;
else l = -MOD;
}
if(l != -MOD)cout << ll(l) << "\n";
else cout << ":(\n";
}else if(K == 1){
cout << A << "\n";
}else if(K == n){
__int128_t l = 0,r = A+1;
__int128_t res = -1ll*MOD*MOD;
while(r-l > 1){
__int128_t mid = (l+r)/2;
__int128_t mn = (A-mid)/(n-1),mx = (A-mid+n-2)/(n-1);
__int128_t l2 = -1,r2 = W;
while(r2-l2 > 1){
__int128_t mid2 = (l2 + r2)/2;
__int128_t k = W - mid2;
__int128_t s = k/(n-1),t = (k+n-2)/(n-1);
if(mid - mid2*(mid2+1)/2 < min(mn - s*(s+1)/2,mx - t*(t+1)/2))r2 = mid2;
else l2 = mid2;
}
__int128_t k = W - r2;
__int128_t s = k/(n-1),t = (k+n-2)/(n-1);
if(mid - r2*(r2+1)/2 < min(mn - s*(s+1)/2,mx - t*(t+1)/2)){
l = mid;
}else{
r = mid;
}
}
__int128_t l2 = -1,r2 = W;
__int128_t mn = (A-l)/(n-1),mx = (A-l+n-2)/(n-1);
while(r2-l2 > 1){
__int128_t mid2 = (l2 + r2)/2;
__int128_t k = W - mid2;
__int128_t s = k/(n-1),t = (k+n-2)/(n-1);
if(l - mid2*(mid2+1)/2 < min(mn - s*(s+1)/2,mx - t*(t+1)/2))r2 = mid2;
else l2 = mid2;
}
__int128_t k = W - r2;
__int128_t s = k/(n-1),t = (k+n-2)/(n-1);
if(l - r2*(r2+1)/2 < min(mn - s*(s+1)/2,mx - t*(t+1)/2))res = max(res,l - r2*(r2+1)/2);
if(res != -1ll*MOD*MOD)cout << ll(res) << "\n";
else cout << ":(\n";
}
}
return 0;
}
ocvret_