結果
問題 | No.1225 I hate I hate Matrix Construction |
ユーザー |
|
提出日時 | 2020-09-12 19:14:28 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 2,000 ms |
コード長 | 1,098 bytes |
コンパイル時間 | 1,711 ms |
コンパイル使用メモリ | 165,248 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2025-01-02 13:15:53 |
合計ジャッジ時間 | 2,832 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 35 |
ソースコード
#include <bits/stdc++.h> #define rep(i,n) for(int i=0;i<(int)n;i++) using namespace std; using ll = long long; using P = pair<int, int>; int main() { int n; cin >> n; vector<int> s(n), t(n); rep(i,n) cin >> s[i]; rep(i,n) cin >> t[i]; vector<vector<int>> ans(n, vector<int>(n, 0)); rep(i,n) { if (s[i] == 2) { rep(j,n) { ans[i][j] = 1; } } } rep(i,n) { if (t[i] == 2) { rep(j,n) { ans[j][i] = 1; } } } int a = 0, b = 0; rep(i,n) { if (s[i] == 1) { bool find = false; rep(j,n) { if (ans[i][j]) find = true; } if (!find) a++; } if (t[i] == 1) { bool find = false; rep(j,n) { if (ans[j][i]) find = true; } if (!find) b++; } } int sum = 0; rep(i,n) { rep(j,n) { sum += ans[i][j]; } } cout << sum + max(a, b) << endl; return 0; }