栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

53. 最大子数组和

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

53. 最大子数组和

  • 思路
    贪心:
    局部最优:如果累加和遇到负数,则将累加和置0,并重新计算累加和
    全局最优:获得最大数组和
class Solution 
{
public:
    int maxSubArray(vector& nums) 
    {
        int res = INT_MIN;
        int tempSum = 0;
        
        if(nums.empty())
        {
            return res;
        }
        
        for(int i = 0; i < nums.size(); ++i)
        {
            tempSum += nums[i];
            
            res = max(res, tempSum);
            
            if(tempSum <= 0)//如果累加和遇到负数,则将累加和置0,并重新计算累加和
            {
                tempSum = 0;
            }
        }
        
        return res;
    }
};

DP:

class Solution 
{
public:
    int maxSubArray(vector& nums) 
    {
        if(nums.size()==1)
        {
            return nums[0];
        }

        vector dp(nums.size(),0);//dp[i]:包括下标i之前的最大连续子序列和为dp[i]
        dp[0]=nums[0];
        int res=dp[0];
        for(int i=1;ires)//保存最大值
            {
            res=dp[i];
            }
        }                                        
        return res;
        }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/630522.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号