题意:
data:image/s3,"s3://crabby-images/0bcfb/0bcfbe9a7ee03b4da258bbc0366121f31769a060" alt=""
data:image/s3,"s3://crabby-images/c623f/c623f5a87bcc8da0e1bde380a367c6ca1ddab61e" alt=""%E6%9C%80%E5%B0%8F(1%3C%3Dj%3C%3Dn)&preview=true)
思路:
data:image/s3,"s3://crabby-images/82b49/82b490040304f6196d65d5afd3c7c0f757ffd7cb" alt=""
data:image/s3,"s3://crabby-images/c9b73/c9b73384c02c4d97e65dac7f14ad59bec4a21dac" alt=""&preview=true)
data:image/s3,"s3://crabby-images/72e4a/72e4af45a5431f3596f86fd4eb4f2a987a6b0945" alt=""
data:image/s3,"s3://crabby-images/52d94/52d944dd2e38eb4bc8449f1d8380ddb0954a694f" alt=""
data:image/s3,"s3://crabby-images/a9b3e/a9b3ed4659c00657799b92f69842a063e2ff0855" alt=""
data:image/s3,"s3://crabby-images/a6652/a66526ebe70b0f843357406060ea25ce85959914" alt=""
data:image/s3,"s3://crabby-images/79c13/79c134111d30267fdda71ca18e48ff3baa0e79a9" alt=""
#include <cstdio>
#include <algorithm>
using namespace std;
const int N = 5e6 + 10;
int n;
int S_a,S_b,S_c,S_d,mod,mx;
int a[N];
bool check(int k){
int b = a[1] - k;//越小越好
for(int i = 2;i <= n;i++){
if(a[i] >= b){
b = max(a[i] - k,b);
}else if(a[i] + k < b) return 0;
}
return 1;
}
int f(int x){
int x_a = 1ll * S_a * x % mod * x % mod* x % mod;
int x_b = 1ll * S_b * x % mod * x % mod;
int x_c = 1ll * S_c * x % mod;
int x_d = S_d % mod;
return (((x_a + x_b)%mod + x_c) % mod + x_d) % mod;
}
int main(){
scanf("%d %d %d %d %d %d %d",&n,&S_a,&S_b,&S_c,&S_d,&a[1],&mod);
mx = a[1];
for(int i = 2;i <= n;i++){
a[i] = (f(a[i - 1]) + f(a[i - 2])) % mod;
mx = max(mx,a[i]);
}
int l = 0,r = mx,ans = -1;
while(l <= r){
int mid = l + r >> 1;
if(check(mid)){
r = mid - 1;
ans = mid;
}else l = mid + 1;
}
printf("%d\n",ans);
return 0;
}