Submission #920671

#TimeUsernameProblemLanguageResultExecution timeMemory
920671OAleksaCouncil (JOI23_council)C++14
78 / 100
4038 ms64116 KiB
#include <bits/stdc++.h> using namespace std; #define int long long #define f first #define s second const int N = 3e5 + 69; const int M = 21; int a[N], cnt[M], n, m; int t[M], k, gas, pr, suf, bt, b, ans, c, s, x; vector<pair<int, int>> g[1030]; pair<pair<int, int>, pair<int, int>> bst[1030][1030]; int kurac[1030][1030]; signed main() { int tt = 1; //cin >> tt; while (tt--) { cin >> n >> m; k = (m + 1) / 2; for (int i = 1;i <= n;i++) { for (int j = 0;j < m;j++) { scanf("%d", &x); if (x > 0) { a[i] |= (1 << j); cnt[j]++; } } pr = (a[i] & ((1 << (m - k)) - 1)); suf = (a[i] >> (m - k)); g[pr].push_back({suf, a[i]}); } for (int i = 0;i < (1 << k);i++) { for (int j = 0;j < (1 << k);j++) { bst[i][j] = {{(1 << m) - 1, m + 1}, {(1 << m) - 1, m + 1}}; kurac[i][j] = __builtin_popcount(i & j); for (auto x : g[i]) { int bt = __builtin_popcount(x.f & j); if (bt < bst[i][j].f.s) { bst[i][j].s = bst[i][j].f; bst[i][j].f = {x.s, bt}; } else if (bt < bst[i][j].s.s) bst[i][j].s = {x.s, bt}; } } } //sufix duzine k, prefix duzine m - k for (int i = 1;i <= n;i++) { b = ans = c = 0; for (int j = 0;j < m;j++) { gas = cnt[j] - ((a[i] & (1 << j)) > 0); if (gas == (n >> 1)) { b |= (1 << j); c++; } else if (gas > (n >> 1)) ans++; } suf = (b >> (m - k)), s = c; pr = (b & ((1 << (m - k)) - 1)); for (int j = 0;j < (1 << (m - k));j++) { if (a[i] != bst[j][suf].f.f) s = min(s, bst[j][suf].f.s + kurac[pr][j]); else s = min(s, bst[j][suf].s.s + kurac[pr][j]); } ans += c - s; printf("%d\n", ans); } } return 0; }

Compilation message (stderr)

council.cpp: In function 'int main()':
council.cpp:21:14: warning: format '%d' expects argument of type 'int*', but argument 2 has type 'long long int*' [-Wformat=]
   21 |      scanf("%d", &x);
      |             ~^   ~~
      |              |   |
      |              |   long long int*
      |              int*
      |             %lld
council.cpp:67:14: warning: format '%d' expects argument of type 'int', but argument 2 has type 'long long int' [-Wformat=]
   67 |     printf("%d\n", ans);
      |             ~^     ~~~
      |              |     |
      |              int   long long int
      |             %lld
council.cpp:21:11: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   21 |      scanf("%d", &x);
      |      ~~~~~^~~~~~~~~~
#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...