結果
問題 | No.43 野球の試合 |
ユーザー | phspls |
提出日時 | 2020-04-12 16:20:57 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 13 ms / 5,000 ms |
コード長 | 1,505 bytes |
コンパイル時間 | 1,755 ms |
コンパイル使用メモリ | 175,380 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-22 02:42:07 |
合計ジャッジ時間 | 2,287 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,376 KB |
testcase_02 | AC | 2 ms
5,376 KB |
testcase_03 | AC | 2 ms
5,376 KB |
testcase_04 | AC | 1 ms
5,376 KB |
testcase_05 | AC | 2 ms
5,376 KB |
testcase_06 | AC | 2 ms
5,376 KB |
testcase_07 | AC | 13 ms
5,376 KB |
testcase_08 | AC | 2 ms
5,376 KB |
testcase_09 | AC | 2 ms
5,376 KB |
testcase_10 | AC | 2 ms
5,376 KB |
ソースコード
#include <bits/stdc++.h> using namespace std; #define rep(i, n) for (int i = 0; i < (int)(n); i++) #define llong long long int getresult(vector<string> &m) { vector<int> wins(m.size(), 0); rep(i, m.size()) rep(j, m.size()) if(m[i][j] == 'o') wins[i] += 1; int val = wins[0]; sort(wins.begin(), wins.end(), greater<int>()); unique(wins.begin(), wins.end()); int ret = distance(wins.begin(), find(wins.begin(), wins.end(), val)) + 1; return ret; } int main() { int n; cin >> n; vector<string> m(n); rep(i, n) cin >> m[i]; int rests = 0; rep(i, n) rep(j, n) if(m[i][j] == '-') rests += 1; rests /= 2; int result = n; if(rests > 0) { rep(i, 1 << rests) { bitset<20> bits(i); vector<string> base = m; int counter = 0; for(int ii=0; ii<n; ii++) { for(int jj=ii+1; jj<n; jj++) { if(base[ii][jj] == '-') { if(bits.test(counter) == 1) { base[ii][jj] = 'o'; base[jj][ii] = 'x'; } else { base[ii][jj] = 'x'; base[jj][ii] = 'o'; } counter++; } } } result = min(getresult(base), result); } } else { result = min(getresult(m), result); } cout << result << "\n"; }