Submission #209477

#TimeUsernameProblemLanguageResultExecution timeMemory
209477my99nHorses (IOI15_horses)C++14
17 / 100
169 ms36984 KiB
#include <bits/stdc++.h> #include "horses.h" using namespace std; const long long mod = 1e9+7; int n; long long seg[2000100], x[500100], y[500100], lazy[2000100]; void build (int now = 1, int l = 0, int r = n-1) { lazy[now] = 1; if (l == r) return void(seg[now] = (x[l]*y[l])%mod); int mid = (l+r)/2; build(now*2, l, mid); build(now*2+1, mid+1, r); seg[now] = max(seg[now*2], seg[now*2+1]); } void push (int now, int l, int r) { if (lazy[now] == 1) return; if (l != r) { lazy[now*2] *= lazy[now]; lazy[now*2] %= mod; lazy[now*2+1] *= lazy[now]; lazy[now*2+1] %= mod; } seg[now] *= lazy[now]; seg[now] %= mod; lazy[now] = 1; } long long query (int now = 1, int l = 0, int r = n-1) { push(now, l, r); return seg[now]; } void update (int a, int b, long long val, int now = 1, int l = 0, int r = n-1) { push(now, l, r); if (r < a or b < l) return; if (a <= l and r <= b) { lazy[now] *= val; lazy[now] %= mod; push(now, l, r); return; } int mid = (l+r)/2; update(a, b, val, now*2, l, mid); update(a, b, val, now*2+1, mid+1, r); seg[now] = max(seg[now*2], seg[now*2+1]); } long long inverse (long long a, long long n = mod-2) { if (n == 1) return a; long long r = inverse(a, n/2); r *= r; r %= mod; if (n&1) return (r*a) % mod; return r; } int init(int N, int X[], int Y[]) { n = N; x[0] = X[0]; for (int i = 1; i < n; i++) { x[i] = X[i]*x[i-1]; x[i] %= mod; } for (int i = 0; i < n; i++) y[i] = Y[i]; for (int i = 0; i <= 4*n; i++) lazy[i] = 1; build(); // for (int i = 0; i < n; i++) cerr << x[i]*y[i] << endl; for (int i = 0; i < n; i++) x[i] = X[i]; return (int)query(); } int updateX(int pos, int val) { update(pos, n-1, inverse(x[pos])); assert(((inverse(x[pos]) * x[pos]) % mod) == 1); x[pos] = val; update(pos, n-1, x[pos]); return query(); } int updateY(int pos, int val) { update(pos, pos, inverse(y[pos])); assert(((inverse(y[pos]) * y[pos]) % mod) == 1); y[pos] = val; update(pos, pos, y[pos]); return query(); }

Compilation message (stderr)

horses.cpp: In function 'long long int inverse(long long int, long long int)':
horses.cpp:49:52: warning: declaration of 'n' shadows a global declaration [-Wshadow]
 long long inverse (long long a, long long n = mod-2) {
                                                    ^
horses.cpp:6:5: note: shadowed declaration is here
 int n;
     ^
horses.cpp: In function 'int updateX(int, int)':
horses.cpp:77:14: warning: conversion to 'int' from 'long long int' may alter its value [-Wconversion]
  return query();
         ~~~~~^~
horses.cpp: In function 'int updateY(int, int)':
horses.cpp:85:14: warning: conversion to 'int' from 'long long int' may alter its value [-Wconversion]
  return query();
         ~~~~~^~
#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...