結果

問題 No.3560 Giant Salamander
コンテスト
ユーザー TKTYI
提出日時 2026-05-21 03:50:28
言語 C++23
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++23 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
RE  
実行時間 -
コード長 1,328 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 3,330 ms
コンパイル使用メモリ 335,812 KB
実行使用メモリ 6,400 KB
最終ジャッジ日時 2026-05-29 18:31:40
合計ジャッジ時間 10,031 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge2_1
このコードへのチャレンジ
(要ログイン)
サブタスク 配点 結果
部分点1 5 % RE * 5
部分点2 20 % AC * 6
部分点3 15 % AC * 6 RE * 5
部分点4 40 % AC * 6 RE * 16
満点 20 % AC * 7 RE * 28
合計 20 点
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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

// subtask 2

int main() {
    int T;
    cin >> T;
    assert(T <= 10);
    while (T--) {
        int N, M;
        cin >> N >> M;
        vector<int> A(M), B(M);
        for (int i = 0; i < M; i++) {
            cin >> A[i] >> B[i];
            A[i]--;
        }
        assert(N <= 8);
        vector<int> P(N);
        iota(P.begin(), P.end(), 0);
        bool ok = false;
        do {
            for (int j = 0; j < (1 << (N - M)); j++) {
                vector<int> S(N, 1);
                bool valid = true;
                for (int i = 0; i < N - M; i++) {
                    int l = P[i] % N, r = (P[i] + 1) % N;
                    if (S[l] == 0 || S[r] == 0) valid = false;
                    if ((j >> i) & 1) {
                        S[r] += S[l];
                        S[l] = 0;
                    }
                    else {
                        S[l] += S[r];
                        S[r] = 0;
                    }
                }
                for (int i = 0; i < M; i++) {
                    if (S[A[i]] != B[i]) valid = false;
                }
                if (valid) ok = 1;
            }
        } while (next_permutation(P.begin(), P.end()));
        if (ok) cout << "Yes" << endl;
        else cout << "No" << endl;
    }
    return 0;
}
0