結果
問題 | No.2147 ハノイの塔のおもちゃ |
ユーザー | norikame |
提出日時 | 2022-12-08 17:43:14 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 1,358 bytes |
コンパイル時間 | 5,762 ms |
コンパイル使用メモリ | 310,764 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-14 14:55:59 |
合計ジャッジ時間 | 6,278 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,248 KB |
testcase_02 | AC | 2 ms
5,248 KB |
testcase_03 | AC | 2 ms
5,248 KB |
testcase_04 | AC | 2 ms
5,248 KB |
testcase_05 | AC | 2 ms
5,248 KB |
testcase_06 | AC | 2 ms
5,248 KB |
testcase_07 | AC | 2 ms
5,248 KB |
testcase_08 | AC | 2 ms
5,248 KB |
testcase_09 | AC | 2 ms
5,248 KB |
testcase_10 | AC | 2 ms
5,248 KB |
testcase_11 | AC | 2 ms
5,248 KB |
ソースコード
// #include <bits/stdc++.h> #include <atcoder/all> using namespace std; using namespace atcoder; using ll = long long; #define rep(i, n) for (int i=0; i<(int)(n); ++(i)) #define rep3(i, m, n) for (int i=(m); (i)<(int)(n); ++(i)) #define repr(i, n) for (int i=(int)(n)-1; (i)>=0; --(i)) #define rep3r(i, m, n) for (int i=(int)(n)-1; (i)>=(int)(m); --(i)) #define all(x) (x).begin(), (x).end() const ll mod = (ll)(1e9) + 7; ll modpow(ll a, ll b) { ll p = 1, q = a; rep(i, 63) { if (b & (1LL<<i)) p = p * q % mod; q = q * q % mod; } return p; } int main() { int n; string s; cin >> n >> s; vector<vector<ll>> memo(n, vector<ll>(3, -1)); auto calc = [&](auto calc, int vi, int ci) -> ll { if (memo[vi][ci] != -1) return memo[vi][ci]; if (vi == 0) { if (ci == s[vi]-'A') return memo[vi][ci] = 0; else return memo[vi][ci] = 1; } else { if (ci == s[vi]-'A') return memo[vi][ci] = calc(calc, vi-1, ci); else { int ti = -1; rep(i, 3) if (i!=ci && i!=s[vi]-'A') { ti = i; break; } return memo[vi][ci] = (calc(calc, vi-1, ti) + 1 + modpow(2, vi) - 1 + mod) % mod; } } }; cout << calc(calc, n-1, 0) << endl; return 0; }