1 条题解

  • 0
    @ 2025-3-3 16:25:49

    C++ :

    #include <bits/stdc++.h>
    using namespace std;
    int main()
    {
        int n,s=0,b[110]={0},max=INT_MIN;
        cin>>n;
        int a[110];
        for(int i=1;i<=n;i++)
        {
            cin>>a[i];
            s=s+a[i];
            b[i]=s;
        }
        for (int i=1;i<=n;i++)
        {
            for (int j=1;j<=n-i+1;j++)
            {
                if (b[j+i-1]-b[j-1]>max) max=b[j+i-1]-b[j-1];
            }
        }
        cout<<max<<endl;
        return 0;
    }
    
    
    • 1

    【基础】最大部分和(连续部分和)

    信息

    ID
    10111
    时间
    1000ms
    内存
    128MiB
    难度
    (无)
    标签
    递交数
    0
    已通过
    0
    上传者