题目:P1115 最大子段和 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
cpp
#include<bits/stdc++.h>
using namespace std;
int n;
signed main(){
std::ios::sync_with_stdio(false);
std::cin.tie(NULL);
cin>>n;
int a[200020],b[200020];
//求最大值时初始化用INT_MIN,要不然会报错
int ans=INT_MIN;
for(int i=1;i<=n;i++){
cin>>a[i];
if(i==1) b[i]=a[i];
//如果一个数加上上一个数,总和减少,就单独取本身,如果总和增大,则取相加之后的数
else b[i]=max(a[i],b[i-1]+a[i]);
//实时更新当前得到的最大序列和
ans=max(ans,b[i]);
}
cout<<ans;
return 0;
}
学到的:
- 变量之间的灵活赋值
- 求最大值函数的灵活应用