This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#ifdef Home
#define _GLIBCXX_DEBUG
#endif // Home
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef long double ld;
const int N = 300300;
int arr[N], sum[22];
main() {
#ifdef Home
freopen("input.txt", "r", stdin);
freopen("output.txt", "w", stdout);
#endif // Home
ios_base::sync_with_stdio(0);
cin.tie(0);
int n, m, n2;
cin >> n >> m;
n2 = n / 2;
map < int, int > mp;
map < int, int > memo;
for(int i = 0, k, t; i < n; ++ i) {
k = 0;
for(int j = m; j --> 0;) {
cin >> t;
k <<= 1;
k |= t;
sum[j] += t;
}
arr[i] = k;
++ mp[k];
}
for(int i = 0, k, ans, mn; i < n; ++ i) {
k = ans = 0;
mn = m;
for(int j = m; j --> 0;) {
ans += (sum[j] - (0 != ((1<<j)&arr[i]))) >= n2;
k <<= 1;
k |= (sum[j] - (0 != ((1<<j)&arr[i]))) == n2;
}
auto it = memo.find(k);
if(it == memo.end()) {
for(auto &[key, val] : mp) {
if(key != arr[i] || val > 1) {
mn = min(mn, __builtin_popcount(k&key));
}
}
memo[k] = mn;
} else {
mn = it->second;
}
cout << ans - mn << '\n';
}
}
Compilation message (stderr)
council.cpp:16:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
16 | main() {
| ^~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |