結果

問題 No.2678 Minmax Independent Set (Hack)
ユーザー NokonoKotlinNokonoKotlin
提出日時 2024-02-11 20:20:01
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 1,492 bytes
コンパイル時間 1,761 ms
コンパイル使用メモリ 177,652 KB
実行使用メモリ 6,816 KB
最終ジャッジ日時 2024-09-29 23:02:13
合計ジャッジ時間 2,126 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>

using namespace std;

// 列が小さすぎて WA の確率が足りない
int main(int argc, char* argv[]) {
    // 3の列 × 1500
    // 5の列 × 1500
    int N = 6000;
    int L = 1500;  // 列の個数
    vector<vector<int>> G(N + 1);

    for (int i = 1; i < L; i++) {
        G[i].push_back(i + 1);
        G[i + 1].push_back(i);
    }
    int id = L + 1;

    for (int u = 1; u <= L; u++) {
        int now = u;

        // 縦に 3 つ
        if (u <= 750) {
            G[now].push_back(id);
            G[id].push_back(now);
            id++;
            G[now].push_back(id);
            G[id].push_back(now);
            id++;
        } else {  // 縦に 5 つ
            G[now].push_back(id);
            G[id].push_back(now);
            now = id;
            id++;
            G[now].push_back(id);
            G[id].push_back(now);
            id++;

            now = u;
            G[now].push_back(id);
            G[id].push_back(now);
            now = id;
            id++;
            G[now].push_back(id);
            G[id].push_back(now);
            id++;
        }
    }

    stack<int> S;
    S.push(1);
    vector<int> visited(N + 1, 0);

    cout << N << endl;
    while (!S.empty()) {
        int now = S.top();
        S.pop();
        visited[now] = 1;

        for (int nx : G[now]) {
            if (visited[nx]) continue;
            cout << now << " " << nx << "\n";
            S.push(nx);
        }
    }

    return 0;
}
0