Submission #488538

#TimeUsernameProblemLanguageResultExecution timeMemory
488538rainboyVolontiranje (COCI21_volontiranje)C11
50 / 110
1 ms460 KiB
#include <stdio.h> #include <stdlib.h> #define N 1000 int max(int a, int b) { return a > b ? a : b; } int ft[N]; void update(int i, int n, int x) { while (i < n) { ft[i] = max(ft[i], x); i |= i + 1; } } int query(int i) { int x = 0; while (i >= 0) { x = max(x, ft[i]); i &= i + 1, i--; } return x; } int *ei[N], eo[N]; void append(int h, int i) { int o = eo[h]++; if (o >= 2 && (o & o - 1) == 0) ei[h] = (int *) realloc(ei[h], o * 2 * sizeof *ei[h]); ei[h][o] = i; } int main() { static int aa[N], nxt[N], hh[N]; int n, h, i, j, l, c; scanf("%d", &n); for (i = 0; i < n; i++) scanf("%d", &aa[i]), aa[i]--; for (i = 0; i < n; i++) update(aa[i], n, (hh[i] = query(aa[i])) + 1); l = query(n - 1); for (h = 0; h < l; h++) ei[h] = (int *) malloc(2 * sizeof *ei[h]); for (i = 0; i < n; i++) { append(hh[i], i); nxt[i] = -1; } c = 0; while (1) { int empty, chain; empty = 0; for (h = 0; h < l; h++) if (eo[h] == 0) { empty = 1; break; } if (empty) break; chain = 1; for (h = 1; h < l; h++) { if (ei[h - 1][eo[h - 1] - 1] > ei[h][eo[h] - 1]) { eo[h - 1]--; chain = 0; break; } if (aa[ei[h - 1][eo[h - 1] - 1]] > aa[ei[h][eo[h] - 1]]) { eo[h]--; chain = 0; break; } } if (!chain) continue; c++; for (h = 0; h < l; h++) { nxt[ei[h][eo[h] - 1]] = h + 1 == l ? n : ei[h + 1][eo[h + 1] - 1]; eo[h]--; } } printf("%d %d\n", c, l); for (i = 0; i < n; i++) if (hh[i] == 0 && nxt[i] != -1) { for (j = i; j < n; j = nxt[j]) printf("%d ", j + 1); printf("\n"); } return 0; }

Compilation message (stderr)

Main.c: In function 'append':
Main.c:32:23: warning: suggest parentheses around '-' in operand of '&' [-Wparentheses]
   32 |  if (o >= 2 && (o & o - 1) == 0)
      |                     ~~^~~
Main.c: In function 'main':
Main.c:41:2: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   41 |  scanf("%d", &n);
      |  ^~~~~~~~~~~~~~~
Main.c:43:3: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   43 |   scanf("%d", &aa[i]), aa[i]--;
      |   ^~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...