题解 | #最大序列和#

最大序列和

https://www.nowcoder.com/practice/df219d60a7af4171a981ef56bd597f7b

动态规划求解(暴力解会超时)

#include <climits>
#include <iostream>
using namespace std;
/*
动态规划:dp[i]存的是以a[i]为结尾的连续子序列的和
*/
int main(){
    int n;
    while (cin >> n){
        int a[n], dp[n];
        for (int i = 0; i < n; i++){
            cin >> a[i];
        }

        dp[0] = a[0];
        int m = a[0];
        for (int i = 1; i < n; i++){
            dp[i] = max(dp[i-1]+a[i],a[i]);
            if (m < dp[i]) m = dp[i];
        }
        cout<< m<<endl;
    }
}

/*暴力解 运行超时
int main() {
    int n;
    while (cin >> n) { // 注意 while 处理多个 case

        int a[n],max = INT_MIN,temp = 0;
        for (int i = 0; i < n; i++){
            cin >> a[i];
            
        }
        
        for (int i = 0; i < n; i++){
            temp = 0;
            for (int j = i; j < n; j++){
                temp += a[j];
                if (max < temp){
                    max = temp;
                }
               // cout<<j<<" "<<max<<" "<<temp<<endl;
            }
            
        }
        cout << max << endl;
    }
}*/
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

10-28 11:04
已编辑
美团_后端实习生(实习员工)
一个2人:我说几个点吧,你的实习经历写的让人觉得毫无含金量,你没有挖掘你需求里的 亮点, 让人觉得你不仅打杂还摆烂。然后你的简历太长了🤣你这个实习经历看完,估计没几个人愿意接着看下去, sdk, 索引这种东西单拎出来说太顶真了兄弟,好好优化下简历吧
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务