1539: 【入门】前缀最小值
内存限制:16 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:6
解决:4
题目描述
求一个数列的所有前缀最小值之和。
即:给出长度为n的数列a[i],求出对于所有1<=i<=n,min(a[1],a[2],...,a[i])的和。
由于读入较大,数列由随机种子生成。
其中a[1]=x,a[i]=(379*a[i-1]+131)%997。
即:给出长度为n的数列a[i],求出对于所有1<=i<=n,min(a[1],a[2],...,a[i])的和。
由于读入较大,数列由随机种子生成。
其中a[1]=x,a[i]=(379*a[i-1]+131)%997。
输入
一行两个正整数n,x,分别表示数列的长度和随机种子。(n<=100000,x<997)
输出
一行一个正整数表示该数列的前缀最小值之和。
样例输入 复制
5 666
样例输出 复制
1650
提示
数列为{666,304,692,188,596},前缀最小值为{666,304,304,188,188},和为1650。
#include<bits/stdc++.h>
using namespace std;
int a[100100],dp[100100],n,i,x,s=0;
int main(){
cin>>n>>x;
a[1]=x;
dp[1]=a[1];
s=dp[1];
for (i = 2;i <=n ;i++) {
a[i]=(379*a[i-1]+131)%997;
dp[i]=max(dp[i-1],a[i]);
s=s+dp[i];
}
cout<<s;
return 0;
}