题目:
class Solution {
public:
int maxSubArray(vector<int>& nums) { //dp[i]表示以nums[i]结尾的连续子数组的最大和
vector<int> dp(nums.size());
int result=nums[0];
dp[0]=nums[0];
for(int i=1;i<nums.size();i++){
dp[i] = max(dp[i-1]+nums[i], nums[i]); //以nums[i]结尾的连续子数组的最大和,要么是和前一个子数组相加的和,要么就是从自身重新计算
result = max(result, dp[i]); //要用result来记录最大和
}
return result;
}
};
分类:
算法编程
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具