結果

問題 No.3558 Dominoes, Black and White
コンテスト
ユーザー jastaway
提出日時 2026-05-26 02:03:34
言語 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
結果
AC  
実行時間 76 ms / 2,000 ms
コード長 903 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 7,824 ms
コンパイル使用メモリ 443,936 KB
実行使用メモリ 13,844 KB
最終ジャッジ日時 2026-05-29 18:41:53
合計ジャッジ時間 14,265 ms
ジャッジサーバーID
(参考情報)
judge2_1 / judge3_0
純コード判定待ち
このコードへのチャレンジ
(要ログイン)
サブタスク 配点 結果
部分点 10 % AC * 30
満点 90 % AC * 89
合計 100 点
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include "testlib.h"
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const ll MAX_N = 1'000;

int main(int argc, char* argv[]) {
    registerValidation(argc, argv);
    ll N = inf.readLong(1, MAX_N, "N");
    inf.readEoln();
    vector<string> S(N);
    int ans = -N*N*(N-1)/2;
    int res = 0;
    int cntw = 0, cntb = 0;
    for(int i = 0; i < N; i++)
    {
        S[i] = inf.readString(format("[.#]{%d,%d}",2*N, 2*N), "S_"+to_string(i));
        int cnt = 0;
        for(int j = 0; j < 2*N; j++)
        {
            if(S[i][j] == '.')
            {
                cntw++;
                ans += j;
                cnt++;
            }
            else
            {
                cntb++;
            }
        }
        ans += abs(res);
        res += cnt - N;
    }
    inf.ensuref(cntw == N*N && cntb == N*N, "invalid S w&b");
    inf.readEof();
    cout << ans << endl;
}
0