結果

問題 No.2278 Time Bomb Game 2
ユーザー miscalcmiscalc
提出日時 2023-04-12 22:42:15
言語 C++17(gcc12)
(gcc 12.3.0 + boost 1.87.0)
結果
AC  
実行時間 8 ms / 2,000 ms
コード長 1,244 bytes
コンパイル時間 2,440 ms
コンパイル使用メモリ 202,368 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2024-11-06 16:59:46
合計ジャッジ時間 4,622 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 70
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
using ll = long long;

// Alice なら true, Bob なら false
bool solve(int N, int K, int T, string S)
{
  // Alice 視点にする
  if (S.at(K) == 'B')
  {
    for (int i = 0; i < N; i++)
    {
      S.at(i) = S.at(i) == 'A' ? 'B' : 'A';
    }
    return !solve(N, K, T, S);
  }

  if ((K != 0 && S.at(K - 1) == 'A') || (K != N - 1 && S.at(K + 1) == 'A'))
  {
    int l = -1, r = -1; // 左右それぞれで初めて出現する 'B' の位置
    for (int i = K - 1; i >= 0; i--)
    {
      if (S.at(i) == 'B')
      {
        l = i;
        break;
      }
    }
    for (int i = K + 1; i < N; i++)
    {
      if (S.at(i) == 'B')
      {
        r = i;
        break;
      }
    }
    if (l != -1 && K - l <= T && (K - l) % 2 == T % 2)
      return true;
    if (r != -1 && r - K <= T && (r - K) % 2 == T % 2)
      return true;
    return false;
  }
  else
  {
    if (T % 2 == 0)
      return false;
    if (K != 0 && solve(N, K - 1, T - 1, S))
      return true;
    if (K != N - 1 && solve(N, K + 1, T - 1, S))
      return true;
    return false;
  }
}

int main()
{
  int N, K, T;
  string S;
  cin >> N >> K >> T >> S;
  K--;
  cout << (solve(N, K, T, S) ? "Alice" : "Bob") << endl;
}
0