题解 | #最大连续子序列#动态规划

最大连续子序列

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

#include <iostream>
using namespace std;
int main() {
    int k;
    while (cin >> k) {
        if (k == 0) break;
        int nums[k];
        bool flag = true;
        for (int i = 0; i < k; i++) {
            cin >> nums[i];
            if (nums[i] >= 0) flag = false;
        }
        if (flag) {
            cout << 0 << ' ' << nums[0] << ' ' << nums[k - 1] << endl;
            continue;
        }
        int dp[k];
        dp[0] = nums[0];
        int maxSum = dp[0];
        int start = 0, end = 0, temp = 0;
        for (int i = 1; i < k; i++) {
            if (dp[i - 1] + nums[i] < nums[i]) {
                dp[i] = nums[i];
                temp = i;
            } else {
                dp[i] = dp[i - 1] + nums[i];
            }
            if (dp[i] > maxSum) {
                maxSum = dp[i];
                start = temp;
                end = i;
            }
        }
        cout << maxSum << ' ' << nums[start] << ' ' << nums[end] << endl;
    }
    return 0;
}

全部评论

相关推荐

03-10 14:19
已编辑
重庆邮电大学 前端工程师
球Offer上岸👑:测试也难求一面 逆天
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务