Submission #793406

#TimeUsernameProblemLanguageResultExecution timeMemory
793406rainboyRPS string (innopolis2021_final_C)C11
100 / 100
15 ms2240 KiB
#include <stdio.h> #include <string.h> #define N 500000 int main() { int t; scanf("%d", &t); while (t--) { static char cc[N + 1], win[N + 1]; int d, n, i, u, v, w, c; scanf("%d%s", &d, cc), n = strlen(cc); for (i = 0; i < n; i++) if (cc[i] == 'r') cc[i] = 0; else if (cc[i] == 'p') cc[i] = 1; else cc[i] = 2; memset(win, '1', n * sizeof *win), win[n] = 0; if (d == 1) { u = 0; for (i = 0; i < n; i++) { c = cc[i]; if ((u & 1 << (c + 1) % 3) != 0 && (u & 1 << (c + 2) % 3) == 0) win[i] = '0'; u |= 1 << c; } u = 0; for (i = n - 1; i >= 0; i--) { c = cc[i]; if ((u & 1 << (c + 1) % 3) != 0 && (u & 1 << (c + 2) % 3) == 0) win[i] = '0'; u |= 1 << c; } } else { u = 0, v = 0, w = 0; for (i = 0; i < n; i++) { c = cc[i]; if ((u & 1 << c) == 0) { if ((u & 1 << (c + 1) % 3) != 0 && (u & 1 << (c + 2) % 3) == 0) win[i] = '0'; } else { if ((u & 1 << (c + 1) % 3) == 0) win[i] = '0'; else if (cc[i - 1] != (c + 2) % 3 && (w & 1 << (c + 2) % 3) == 0) win[i] = '0'; } if ((v & 1 << (c + 1) % 3) != 0) w |= 1 << (c + 1) % 3; if (i == 0 || (u & 1 << (c + 2) % 3) != 0) v |= 1 << c; u |= 1 << c; } u = 0, v = 0, w = 0; for (i = n - 1; i >= 0; i--) { c = cc[i]; if ((u & 1 << c) == 0) { if ((u & 1 << (c + 1) % 3) != 0 && (u & 1 << (c + 2) % 3) == 0) win[i] = '0'; } else { if ((u & 1 << (c + 1) % 3) == 0) win[i] = '0'; else if (cc[i + 1] != (c + 2) % 3 && (w & 1 << (c + 2) % 3) == 0) win[i] = '0'; } if ((v & 1 << (c + 1) % 3) != 0) w |= 1 << (c + 1) % 3; if (i == n - 1 || (u & 1 << (c + 2) % 3) != 0) v |= 1 << c; u |= 1 << c; } } printf("%s\n", win); } return 0; }

Compilation message (stderr)

Main.c: In function 'main':
Main.c:9:2: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
    9 |  scanf("%d", &t);
      |  ^~~~~~~~~~~~~~~
Main.c:14:3: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   14 |   scanf("%d%s", &d, cc), n = strlen(cc);
      |   ^~~~~~~~~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...