結果

問題 No.3484 Just a Maze Game
コンテスト
ユーザー GOTKAKO
提出日時 2026-03-27 22:24:28
言語 C++17
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++17 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
AC  
実行時間 48 ms / 2,000 ms
コード長 814 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,300 ms
コンパイル使用メモリ 219,652 KB
実行使用メモリ 9,088 KB
最終ジャッジ日時 2026-03-27 22:24:30
合計ジャッジ時間 2,042 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 24
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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

int main(){
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);

    int T; cin >> T;
    map<tuple<int,int,int>,bool> memo; 
    auto dfs = [&](auto dfs,int n,int m,int b) -> bool {
        if(min(n,m) == 1) return false;
        if(memo.count({n,m,b})) return memo[{n,m,b}];
        long long left = 2*n+2*m-4,w = n*m-b;
        bool ret = false;
        if(left <= w || left%2 == w%2) ret = true;
        else{
            if(b >= m && dfs(dfs,n-1,m,b-m)) ret = true;
            else if(b >= n && dfs(dfs,n,m-1,b-n)) ret = true;
        }
        memo[{n,m,b}] = ret;
        return ret;
    };
    while(T--){
        long long N,M,B,W; cin >> N >> M >> B >> W;
        if(dfs(dfs,N,M,B)) cout << "Alice\n";
        else cout << "Bob\n";
        
    }
}
0