Submission #795059

#TimeUsernameProblemLanguageResultExecution timeMemory
795059vjudge1Council (JOI23_council)C++17
41 / 100
4038 ms4440 KiB
#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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...