第24002题 单选
C++求最大连续子数组和动态规划代码的横线填充选择题

给定一个整数数组 nums,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。以下是部分代码(横线处待填):

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int maxSubArray(vector<int>& nums) {
    int n = nums.size();
    if (n == 0) return 0;

    vector<int> dp(n, 0);
    dp[0] = nums[0];
    int maxSum = dp[0];

    for (int i = 1; i < n; i++) {
        // 此处为横线位置
        maxSum = max(maxSum, dp[i]);
    }

    return maxSum;
}

int main() {
    int n;
    cin >> n;

    vector<int> nums(n);
    for (int i = 0; i < n; i++) {
        cin >> nums[i];
    }

    int result = maxSubArray(nums);
    cout << result << endl;

    return 0;
}
A

dp[i] = max(nums[i+1], dp[i - 1] + nums[i]);

B

dp[i] = max(nums[i], dp[i - 1] + nums[i]);

C

dp[i] = max(nums[i], dp[i + 1] + nums[i]);

D

dp[i] = max(nums[i], dp[i - 1] + nums[i+1]);