結果
問題 | No.973 余興 |
ユーザー | paruki |
提出日時 | 2020-01-27 20:15:28 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 1,063 ms / 4,000 ms |
コード長 | 2,013 bytes |
コンパイル時間 | 1,743 ms |
コンパイル使用メモリ | 168,852 KB |
実行使用メモリ | 137,088 KB |
最終ジャッジ日時 | 2024-09-14 13:16:27 |
合計ジャッジ時間 | 36,241 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 54 |
ソースコード
#define _USE_MATH_DEFINES #include "bits/stdc++.h" using namespace std; #define FOR(i,j,k) for(int (i)=(j);(i)<(int)(k);++(i)) #define rep(i,j) FOR(i,0,j) #define each(x,y) for(auto &(x):(y)) #define mp make_pair #define MT make_tuple #define all(x) (x).begin(),(x).end() #define debug(x) cout<<#x<<": "<<(x)<<endl #define smax(x,y) (x)=max((x),(y)) #define smin(x,y) (x)=min((x),(y)) #define MEM(x,y) memset((x),(y),sizeof (x)) #define sz(x) (int)(x).size() #define RT return using ll = long long; using pii = pair<int, int>; using vi = vector<int>; using vll = vector<ll>; const int MA = 5003; int lr[MA][MA], rl[MA][MA], toLeft[MA], toRight[MA]; void solve() { int N, X; cin >> N >> X; vi A(N); rep(i, N) { cin >> A[i]; } rep(i, N) { ll sum = 0; FOR(j, i, N) { sum += A[j]; if (sum > X) { break; } // [i, j] toRight[i] = j; } sum = 0; for (int j = i; j >= 0; --j) { sum += A[j]; if (sum > X) { break; } // [j, i] toLeft[i] = j; } } int res = 0; for (int len = 2; len <= N; ++len) { for (int i = 0; i + len <= N; ++i) { lr[i][i + len] += lr[i][i + len - 1]; rl[i + len][i] += rl[i + len][i + 1]; } for (int i = 0; i + len <= N; ++i) { res = lr[i][i + len] + rl[i + len][i] > 0 ? 1 : 0; if (res == 0) { lr[i][i + len + 1]++; lr[i][toRight[i + len] + 1 + 1]--; if (i > 0) { rl[i + len][i - 1]++; if (toLeft[i - 1] > 0) { rl[i + len][toLeft[i - 1] - 1]--; } } } } } cout << (res ? 'A' : 'B') << endl; } int main() { ios::sync_with_stdio(false); cin.tie(0); cout << fixed << setprecision(15); solve(); return 0; }