题目:P1115 最大子段和 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
法一:
#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;
}
法二:
#include<bits/stdc++.h>
using namespace std;
int sum=0;
int a[2]; //滚动数组
signed main(){
int n;
cin>>n;
cin>>a[1];
sum=a[1];
for(int i=2;i<=n;i++){
if(sum<0) sum=0;
cin>>a[i%2];
sum+=a[i%2];
a[i%2]=max(a[(i-1)%2],sum);
}
cout<<a[n%2];
return 0;
}
暴力算法:
#include<bits/stdc++.h>
using namespace std;
int MaxSum(int *a,int n){
int sum=0,b=0;
for(int i=1;i<=n;i++){
if(b>0){
b+=a[i];
}else{
b=a[i];
}
if(b>sum)
sum=b;
}
return sum;
}
signed main(){
int a[100],n;
cout<<"请输入元素的个数:";
cin>>n;
cout<<"请输入各个元素:";
for(int i=1;i<=n;i++){
cin>>a[i];
}
cout<<endl<<"序列";
for(int i=1;i<=n;i++){
if(i==n){
cout<<a[i];
}else
cout<<a[i]<<",";
}
cout<<"的最大字段和为:"<<MaxSum(a,n)<<endl;
return 0;
}
学到的:
- 变量之间的灵活赋值
- 求最大值函数的灵活应用