当前位置:首页 > 题解目录 > 正文内容

【题解】前缀最大值

亿万年的星光3年前 (2022-10-20)题解目录2600

【题目描述】

求一个数列的所有前缀最大值之和。
即:给出长度为n的数列a[i],求出对于所有1<=i<=n,max(a[1],a[2],...,a[i])的和。
比如,有数列:666 304 692 188 596,前缀最大值为:666 666 692 692 692,和为3408。
对于每个位置的前缀最大值解释如下:对于第1个数666,只有一个数,一定最大;对于第2个数,求出前两个数的最大数,还是666;对于第3个数,求出前3个数的最大数是692……其余位置依次类推,最后求前缀最大值得和。

由于读入较大,数列由随机种子生成。
其中a[1]=x,a[i]=(379*a[i-1]+131)%997。

【输入描述】

一行两个正整数n,x,分别表示数列的长度和随机种子。(n<=100000,x<997)

【输出描述】

一行一个正整数表示该数列的前缀最大值之和。

【样例输入】

5 666
Copy


【样例输出】

3408

【提示】

数列为{666,304,692,188,596},前缀最大值为{666,666,692,692,692},和为3408。



【参考代码】

#include<bits/stdc++.h>
using namespace std;
int n,x,a[100001],k,sum;
int main(){
	cin>>n>>x;
	sum = k = a[1] = x;
	for(int i=2;i<=n;i++) {
		a[i]=(379*a[i-1]+131)%997;
	}
	for(int i=2;i<=n;i++){
		if(k > a[i]) {
			a[i] = k;
		}else{
			k = a[i];
		}
		sum += a[i];
	}
	cout<<sum;
	return 0;
}


写法二:

#include<bits/stdc++.h> 
using namespace std;
int n,x,maxx;
long long s;
int main()
{
	scanf("%d %d",&n,&x);
	maxx=x;s=x;
	for(int i=2;i<=n;i++)
	{
		x=(379*x+131)%997;
		maxx=max(maxx,x);
		s+=maxx;
	}
	printf("%lld",s);
	return 0;
}


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    【题解】演讲大赛评分

    【题目描述】最近"老王"很开心.他在大一的时候参加过数计学院的“软件小组”。告诉你个秘密,这个小组是个好地方,不但活动精彩而且有MM。 这不,这个小组举办了一个叫做“计算...

    【题解】电池的寿命

    【题目描述】小S新买了一个掌上游戏机,这个游戏机由两节5号电池供电。为了保证能够长时间玩游戏,他买了很多5号电池,这些电池的生产商不同,质量也有差异,因而使用寿命也有所不同,有的能使用5个小时,有的可...

    【题解】吃糖果

    【题解】吃糖果

    【题目描述】小明终于从小红手里赢走了所有的糖果,小明转变吃掉所有糖果,但是小明吃糖果有个特殊癖好,就是不喜欢将一样的糖果放在一起吃,喜欢先吃一种,下一次吃另外一种。试问小明是否存在一种吃糖果的顺序使得...

    【题解】寻找祖先

    【题解】寻找祖先

    【题目描述】给出充足的父子关系,请你编写程序找到某个人的最早的祖先。规定每个人的名字都没有空格,且没有任意两个人的名字相同。最多可能有1000组父子关系,总人数最多可能达到50000人,家谱中的记载不...

    【题解】最长上升子序列

    【题目描述】一个数的序列bi,当b1<b2<...<bS的时候,我们称这个序列是上升的。对于给定的一个序列(a1,a2,...,aN),我们可以得到一些上升的子序列(ai1,ai2,...

    【题解】单词接龙

    【题目描述】单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重...