求助100pts但WA一个点
查看原帖
求助100pts但WA一个点
1027430
hlb44楼主2024/10/23 19:16

代码:代码:

#include<bits/stdc++.h>
using namespace std;
int n,flag=0;
long long p;
const int cs=1e6+10;
long long a[cs],dp[cs],f[cs],s[cs],ans;//手上的数字,最大子段和,特征值,分数 
int main()
{
	cin>>n>>p;
	for(int i=1;i<=n;i++)cin>>a[i];
	f[1]=dp[1]=a[1];
	for(int i=2;i<=n;i++)
	{
		dp[i]=max(a[i],dp[i-1]+a[i]);
		f[i]=max(f[i-1],dp[i]);
	}
	ans=s[1]=f[1];
	s[2]=f[1]+s[1];
	ans=max(ans,s[2]);
	for(int i=3;i<=n;i++)
	{
		ans=max(ans,f[i-1]+s[i-1]);
		if(s[i-1]+f[i-1]<0 && s[i-1]>0)flag=1;
		if(flag)s[i]=(s[i-1]%p+f[i-1]%p)%p;
		else s[i]=max(s[i-1],s[i-1]+f[i-1]);
		ans=max(ans,s[i]);
	}
	if(flag)cout<<s[n]%p;
	else cout<<ans%p;
	return 0;
}
2024/10/23 19:16
加载中...