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 "grader.cpp"
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define all(s) s.begin(), s.end()
#define pb push_back
#define fr first
#define sc second
#define vl vector < ll >
#define pl pair < ll, ll >
const int MN = 5e5 + 7;
const ll mod = 1e9 + 7;
ll t[4 * MN], m[4 * MN];
ll x[MN], y[MN], pr[MN];
set < int > p;
int n;
void build (int v, int l, int r){
if (l == r){
t[v] = x[l];
m[v] = y[l];
}
else {
int mid = (l + r) >> 1;
build(v + v, l, mid);
build(v + v + 1, mid + 1, r);
t[v] = (t[v + v] * t[v + v + 1]) % mod;
m[v] = max(m[v + v], m[v + v + 1]);
}
}
void upd (int v, int l, int r, int pos, ll val){
if (l == r)
t[v] = val;
else {
int mid = (l + r) >> 1;
if (pos <= mid)
upd(v + v, l, mid, pos, val);
else
upd(v + v + 1, mid + 1, r, pos, val);
t[v] = (t[v + v] * t[v + v + 1]) % mod;
}
}
void upd_m (int v, int l, int r, int pos, ll val){
if (l == r)
m[v] = val;
else {
int mid = (l + r) >> 1;
if (pos <= mid)
upd_m(v + v, l, mid, pos, val);
else
upd_m(v + v + 1, mid + 1, r, pos, val);
m[v] = max(m[v + v], m[v + v + 1]);
}
}
ll get (int v, int l, int r, int ql, int qr){
if (ql <= l && r <= qr)
return t[v];
if (r < ql || qr < l)
return 1LL;
int mid = (l + r) >> 1;
return (get(v + v, l, mid, ql, qr) * get(v + v + 1, mid + 1, r, ql, qr)) % mod;
}
ll get_m (int v, int l, int r, int ql, int qr){
if (ql <= l && r <= qr)
return m[v];
if (r < ql || qr < l)
return 1LL;
int mid = (l + r) >> 1;
return max(get_m(v + v, l, mid, ql, qr), get_m(v + v + 1, mid + 1, r, ql, qr));
}
int answer(){
vl v;
v.clear();
ll s = 1;
for (int it : p){
if (s >= mod)
break;
int i = -it;
s *= x[i];
v.pb(i);
}
ll temp = s;
if (temp < mod)
v.pb(0);
int sz = v.size();
ll mx = 0, yy = 0;
s = 1;
for (int i = sz - 2; i >= 0; i--){
s *= x[v[i]];
if (i)
yy = get_m(1, 1, n, v[i], v[i - 1] - 1);
else
yy = get_m(1, 1, n, v[i], n);
mx = max(mx, s * yy);
}
if (v[sz - 1] == 0){
yy = get_m(1, 1, n, 1, n);
return max(mx, yy) % mod;
}
else {
if (temp < mod)
assert(false);
if (sz > 1)
yy = get_m(1, 1, n, v[sz - 1], v[sz - 2] - 1);
else
yy = get_m(1, 1, n, v[sz - 1], n);
return (max(mx, yy) % mod * get(1, 1, n, 1, v[sz - 1])) % mod;
}
}
int init(int N, int X[], int Y[]){
n = N;
x[0] = 1LL;
y[0] = 1LL;
for (int i = 1; i <= n; i++){
x[i] = X[i - 1];
y[i] = Y[i - 1];
if (x[i] != 1)
p.insert(-i);
}
build(1, 1, n);
return answer();
}
int updateX(int pos, int val) {
pos++;
upd(1, 1, n, pos, 1LL * val);
if (x[pos] != 1 && val == 1)
p.erase(pos);
if (x[pos] == 1 && val != 1)
p.insert(pos);
x[pos] = 1LL * val;
return answer();
}
int updateY(int pos, int val) {
pos++;
upd_m(1, 1, n, pos, 1LL * val);
y[pos] = 1LL * val;
return answer();
}
Compilation message (stderr)
horses.cpp: In function 'int answer()':
horses.cpp:95:20: warning: conversion from 'std::vector<long long int>::size_type' {aka 'long unsigned int'} to 'int' may change value [-Wconversion]
95 | int sz = v.size();
| ~~~~~~^~
horses.cpp:101:51: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
101 | yy = get_m(1, 1, n, v[i], v[i - 1] - 1);
| ^
horses.cpp:101:48: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
101 | yy = get_m(1, 1, n, v[i], v[i - 1] - 1);
horses.cpp:103:40: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
103 | yy = get_m(1, 1, n, v[i], n);
| ^
horses.cpp:108:28: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
108 | return max(mx, yy) % mod;
| ~~~~~~~~~~~~^~~~~
horses.cpp:114:57: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
114 | yy = get_m(1, 1, n, v[sz - 1], v[sz - 2] - 1);
| ^
horses.cpp:114:54: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
114 | yy = get_m(1, 1, n, v[sz - 1], v[sz - 2] - 1);
horses.cpp:116:45: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
116 | yy = get_m(1, 1, n, v[sz - 1], n);
| ^
horses.cpp:117:62: warning: conversion from '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} to 'int' may change value [-Wconversion]
117 | return (max(mx, yy) % mod * get(1, 1, n, 1, v[sz - 1])) % mod;
| ^
horses.cpp:117:65: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
117 | return (max(mx, yy) % mod * get(1, 1, n, 1, v[sz - 1])) % mod;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~
# | 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... |