結果
問題 | No.582 キャンディー・ボックス3 |
ユーザー | tsutaj |
提出日時 | 2019-03-29 18:49:45 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,518 bytes |
コンパイル時間 | 953 ms |
コンパイル使用メモリ | 104,912 KB |
実行使用メモリ | 18,340 KB |
最終ジャッジ日時 | 2024-11-07 01:21:44 |
合計ジャッジ時間 | 2,032 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 17 ms
17,468 KB |
testcase_01 | AC | 17 ms
17,028 KB |
testcase_02 | AC | 16 ms
18,044 KB |
testcase_03 | AC | 17 ms
18,340 KB |
testcase_04 | AC | 17 ms
17,048 KB |
testcase_05 | AC | 17 ms
17,212 KB |
testcase_06 | AC | 17 ms
17,692 KB |
testcase_07 | AC | 17 ms
18,228 KB |
testcase_08 | WA | - |
testcase_09 | WA | - |
testcase_10 | AC | 18 ms
17,868 KB |
testcase_11 | AC | 17 ms
17,560 KB |
testcase_12 | AC | 18 ms
17,852 KB |
testcase_13 | AC | 17 ms
16,744 KB |
testcase_14 | AC | 17 ms
17,536 KB |
testcase_15 | AC | 17 ms
17,504 KB |
testcase_16 | WA | - |
testcase_17 | AC | 17 ms
17,424 KB |
testcase_18 | AC | 17 ms
17,784 KB |
testcase_19 | AC | 17 ms
18,160 KB |
ソースコード
// #define _GLIBCXX_DEBUG // for STL debug (optional) #include <iostream> #include <iomanip> #include <cstdio> #include <string> #include <cstring> #include <deque> #include <list> #include <queue> #include <stack> #include <vector> #include <utility> #include <algorithm> #include <map> #include <set> #include <complex> #include <cmath> #include <limits> #include <cfloat> #include <climits> #include <ctime> #include <cassert> #include <numeric> #include <fstream> #include <functional> #include <bitset> using namespace std; #define debug(...) fprintf(stderr, __VA_ARGS__) #define int long long int template<typename T> void chmax(T &a, T b) {a = max(a, b);} template<typename T> void chmin(T &a, T b) {a = min(a, b);} template<typename T> void chadd(T &a, T b) {a = a + b;} typedef pair<int, int> pii; typedef long long ll; int dx[] = {0, 0, 1, -1}; int dy[] = {1, -1, 0, 0}; const ll INF = 1001001001001001LL; const ll MOD = 1000000007LL; const int S = 10; int rec[S+5][S+5][S+5][S+5][S+5][3]; int solve(int a, int b, int c, int d, int e, int turn) { int &val = rec[a][b][c][d][e][turn]; if(val >= 0) return val; val = 0; int n_turn = 3 - turn; for(int i=1; i<=turn; i++) { if(i <= a) val |= !solve(a-i, b , c , d , e , n_turn); if(i <= b) val |= !solve(a , b-i, c , d , e , n_turn); if(i <= c) val |= !solve(a , b , c-i, d , e , n_turn); if(i <= d) val |= !solve(a , b , c , d-i, e , n_turn); if(i <= e) val |= !solve(a , b , c , d , e-i, n_turn); } return val; } void test() { fill(rec[0][0][0][0][0], rec[S+1][0][0][0][0], -1); for(int i=0; i<=S; i++) { for(int j=i; j<=S; j++) { for(int k=j; k<=S; k++) { for(int l=k; l<=S; l++) { for(int m=l; m<=S; m++) { // 先手が勝ち if(solve(i, j, k, l, m, 1) == 1) { fprintf(stderr, "winner is A: %lld, %lld, %lld, %lld, %lld\n", i, j, k, l, m); } } } } } } } signed main() { test(); int N; cin >> N; int cnt1 = 0, cnt2 = 0, cntF = 0; for(int i=0; i<N; i++) { int C; cin >> C; if(C == 1) cnt1++; else if(C == 2) cnt2++; else cntF++; } bool ok = true; ok &= (cnt1 % 2 == 1); ok &= (cnt2 <= 1); ok &= (cntF == 0); cout << (ok ? "A" : "B") << endl; return 0; }