Submission #795062

#TimeUsernameProblemLanguageResultExecution timeMemory
795062vjudge1Council (JOI23_council)C++17
41 / 100
4073 ms3012 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], memo[1<<14];

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;
        }
        if(!memo[k]) {
            for(auto &[key, val] : mp) {
                if(key != arr[i] || val > 1) {
                    mn = min(mn, __builtin_popcount(k&key));
                }
            }
            memo[k] = mn + 1;
        } else {
            mn = memo[k] - 1;
        }
        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...