Submission #973776

#TimeUsernameProblemLanguageResultExecution timeMemory
973776sleepntsheepRelativnost (COCI15_relativnost)C11
0 / 140
149 ms12716 KiB
#include <stdio.h> #define N 100000 #define C 20 const long long MOD = 10007; int power(int a,int b) { if (!b) return 1; int r = power(a, b/2); if(b&1)return r*1ll*r%MOD*a%MOD; return r*1ll*r%MOD; } int q, n, c, a[N], b[N], p, aa, bb; int t[N][C+1], tt[N]; void base(int i) { t[i+n][0] = b[i] % MOD; t[i+n][1] = a[i] % MOD; tt[i+n] = (a[i] + 0ll + b[i]) % MOD; } void pul(int i) { for (int j = 0; j < c; ++j) { t[i][j] = 0; for (int k = 0; k <= j; ++k) t[i][j] = (t[i][j] + t[i<<1][k] * 1ll * t[i<<1|1][j-k] % MOD) % MOD; } tt[i] = tt[i<<1] * 1ll * tt[i<<1|1] % MOD; } int main() { scanf("%d%d",&n,&c); if (c > n) return puts("0"), 0; for (int i = 0; i < n; ++i) scanf("%d%d", a+i, b+i), base(i); for (int i = n; --i;) pul(i); scanf("%d", &q); while (q--) { scanf("%d%d%d", &p, &aa, &bb), --p; a[p] = aa, b[p] = bb; base(p); for (p+=n;p>>=1;) pul(p); int ans = tt[1]; for (int i = 0; i < c; ++i) ans = (ans + MOD - t[1][i]) % MOD; printf("%d\n", ans); } }

Compilation message (stderr)

relativnost.c: In function 'main':
relativnost.c:39:5: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   39 |     scanf("%d%d",&n,&c);
      |     ^~~~~~~~~~~~~~~~~~~
relativnost.c:43:33: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   43 |     for (int i = 0; i < n; ++i) scanf("%d%d", a+i, b+i), base(i);
      |                                 ^~~~~~~~~~~~~~~~~~~~~~~
relativnost.c:46:5: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   46 |     scanf("%d", &q);
      |     ^~~~~~~~~~~~~~~
relativnost.c:49:9: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   49 |         scanf("%d%d%d", &p, &aa, &bb), --p;
      |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...