# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
310052 | tengiz05 | Horses (IOI15_horses) | C++17 | 1586 ms | 16000 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "horses.h"
#include <bits/stdc++.h>
typedef long double ld;
typedef long long ll;
using namespace std;
int n;
const int NN = 5e5+5;
const ll mod = 1e9+7;
ll a[NN];
ll b[NN];
int init(int N, int X[], int Y[]) {
n = N;
for(int i=0;i<n;i++)a[i] = X[i];
for(int i=0;i<n;i++)b[i] = Y[i];
ll cnt = 1, ans = 0;
ld d=0.;
ld mx=-1;
for(int i=0;i<n;i++){
cnt *= a[i];
cnt %= mod;
d = d+log2((ld)a[i]);
if(mx < d+log2(b[i])){
mx = d+log2(b[i]);
ans = ((ll)cnt*b[i])%mod;
}
}
return ans;
}
int updateX(int pos, int val) {
a[pos] = val;
ll cnt = 1, ans = 0;
ld d=0.;
ld mx=-1;
for(int i=0;i<n;i++){
cnt *= a[i];
cnt %= mod;
d = d+log2((ld)a[i]);
if(mx < d+log2(b[i])){
mx = d+log2(b[i]);
ans = ((ll)cnt*b[i])%mod;
}
}
return ans%mod;
}
int updateY(int pos, int val) {
b[pos] = val;
ll cnt = 1, ans = 0;
ld d=0.;
ld mx=-1;
for(int i=0;i<n;i++){
cnt *= a[i];
cnt %= mod;
d = d+log2((ld)a[i]);
if(mx < d+log2(b[i])){
mx = d+log2(b[i]);
ans = ((ll)cnt*b[i])%mod;
}
}
return ans%mod;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |