社区讨论

0pts求助

P1982[NOIP 2013 普及组] 小朋友的数字参与者 2已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@m21m5q9k
此快照首次捕获于
2024/10/09 16:34
去年
此快照最后确认于
2025/11/04 17:35
4 个月前
查看原帖
代码
CPP
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e6+5;
ll n,dp[N],a[N],mx=INT_MIN,f[N],mod;
int main(){
	cin>>n>>mod;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	dp[1]=a[1];
	mx=max(mx,a[1]);
	for(int i=2;i<=n;i++){
		dp[i]=max(dp[i-1]+a[i],max(a[i],mx));
		mx=max(dp[i],max(a[i],mx));
	}
	/*for(int i=1;i<=n;i++){
		cout<<dp[i]<<" ";
	}*/
	//cout<<endl;
	mx=a[1];
	f[1]=a[1];
	f[2]=2*a[1];
	mx=max(max(mx,f[1]+dp[1]),dp[2]+f[2]);
	for(int i=3;i<=n;i++){
		f[i]=mx;
		mx=max(mx,dp[i]+f[i]);
	}
	/*for(int i=1;i<=n;i++){
		cout<<f[i]<<" ";
	}*/
	cout<<endl;
	cout<<f[n]%mod;
	return 0;
} 

回复

1 条回复,欢迎继续交流。

正在加载回复...