結果
問題 | No.153 石の山 |
ユーザー |
|
提出日時 | 2019-10-19 15:29:15 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,836 bytes |
コンパイル時間 | 1,582 ms |
コンパイル使用メモリ | 174,724 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-27 05:23:35 |
合計ジャッジ時間 | 2,563 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 27 |
ソースコード
// aribon4-2_e// yukicoder No.153 石の山#include <bits/stdc++.h>#ifdef LOCAL#include "../cxx-prettyprint/prettyprint.hpp"#endifusing namespace std;typedef long long ll;typedef unsigned long long ull;typedef pair<int, int> P;#define REP(i, n) for (int (i) = 0 ; (i) < (int)(n) ; ++(i))#define REPN(i, m, n) for (int (i) = m ; (i) < (int)(n) ; ++(i))#define REP_REV(i, n) for (int (i) = (int)(n) - 1 ; (i) >= 0 ; --(i))#define REPN_REV(i, m, n) for (int (i) = (int)(n) - 1 ; (i) >= m ; --(i))#define ALL(x) x.begin(), x.end()#define INF ((1 << 29)-1)#define MOD (1000000007)#define print2D(h, w, arr) REP(i, h) { REP(j, w) cout << arr[i][j] << " "; cout << endl; }#define print_line(vec, n) {for(int i=0;i<(n-1);i++) cout << (vec)[i] << " "; cout << (vec)[(n)-1] << endl;}template<class T> void print(const T& x){cout << x << endl;}template<class T, class... A> void print(const T& first, const A&... rest) { cout << first << " "; print(rest...); }struct PreMain {PreMain(){cin.tie(0);ios::sync_with_stdio(false);cout<<fixed<<setprecision(20);}} premain;vector<int> grundy;int rec(int n){if (grundy[n] != -1) return grundy[n];set<int> s;int g;if (n % 2 == 0){g = 0;} else {g = rec(n/2) ^ rec(n/2 + 1);}s.insert(g);int g2;if (n % 3 == 0){g2 = rec(n/3);} else if (n % 3 == 1){g2 = rec(n/3 + 1);} else {g2 = rec(n/3);}s.insert(g2);int res = 0;while(s.count(res)) res++;return grundy[n] = res;}int main() {#ifdef LOCALifstream in("../arg.txt"); cin.rdbuf(in.rdbuf());#endifint N;cin >> N;grundy.assign(N+1, -1);grundy[0] = 0;grundy[1] = 0;if (rec(N) == 0) {print("B");} else {print("A");}return 0;}