-4
#include<iostream>
#include<climits>
using namespace std;
int main(){
    int n;
    cin>>n;
    int a[n];
    for(int i=0;i<n;++i){
        cin>>a[n];
    }                                       //array instillisation
    int cursum=0;
    int maxsum=INT_MIN;
    for(int i=0;i<n;++i){
             cursum+=a[i];
             if(cursum<0){
                cursum=0;
             }
             maxsum=max(cursum,maxsum);
                }
      cout<<maxsum<<endl;               
      return 0; 
}

//此代码用于使用 kadane 算法的最大子数组问题。我的编译器返回错误的输出

4

1 回答 1

2

cin您进行不正确的操作时,它应该是

 cin>> a[i];

你正在做的是取 a[n] 的值

于 2021-03-14T07:36:31.933 回答