Submission #823177

#TimeUsernameProblemLanguageResultExecution timeMemory
823177rainboyBinaria (CCO23_day1problem1)C11
25 / 25
103 ms15916 KiB
#include <stdio.h> #define N 1000000 #define MD 1000003 int vv[N + 1], ff[N + 1], gg[N + 1]; void init() { int i; ff[0] = gg[0] = 1; for (i = 1; i <= N; i++) { vv[i] = i == 1 ? 1 : (long long) vv[i - MD % i] * (MD / i + 1) % MD; ff[i] = (long long) ff[i - 1] * i % MD; gg[i] = (long long) gg[i - 1] * vv[i] % MD; } } int choose(int n, int k) { return k < 0 || k > n ? 0 : (long long) ff[n] * gg[k] % MD * gg[n - k] % MD; } int main() { static int kk[N]; int n, k, i, r, a, k1, k01; init(); scanf("%d%d", &n, &k); for (i = 0; i + k <= n; i++) scanf("%d", &kk[i]); k01 = k1 = 0; for (r = 0; r < k; r++) { a = -1; for (i = r; i + k < n; i += k) if (kk[i + 1] != kk[i]) { if (kk[i + 1] - kk[i] == 1) a = 0; else if (kk[i + 1] - kk[i] == -1) a = 1; else a = -2; break; } if (a == -2) { printf("0\n"); return 0; } if (a == -1) { k01++; continue; } if (a == 1) k1++; for (i = r; i + k < n; i += k) { a += kk[i + 1] - kk[i]; if (a != 0 && a != 1) { printf("0\n"); return 0; } } } printf("%d\n", choose(k01, kk[0] - k1)); return 0; }

Compilation message (stderr)

Main.c: In function 'main':
Main.c:28:2: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   28 |  scanf("%d%d", &n, &k);
      |  ^~~~~~~~~~~~~~~~~~~~~
Main.c:30:3: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   30 |   scanf("%d", &kk[i]);
      |   ^~~~~~~~~~~~~~~~~~~
#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...