leetcode 1749.任意子数组和的绝对值的最大值

思路:dp

说到绝对值,大家肯定不陌生,但是用在dp上就会使问题变得稍微复杂一些了。

我们在最大子数组和的那道题中知道,在状态转移的时候,我们会舍弃掉为负数的连续部分,重新构建连续的子串。但是,这里不一样,我们并不能轻易舍弃负数的部分,负数也可能让这个子数组和的绝对值变成最大的,例如0,-1000,1,2这个序列就很典型,我们如果按照上一个题那样做,就会使最大值变成3,而不是1000。

这里给出的思路,就是把最大子数组和与最小子数组和之间,两者分别取绝对值,然后比较谁大这个思路,这样就能考虑到最大子数组和中没有考虑到的把负数加进来的讨论了。

这里用了两个dp数组,一个代表最大子数组和,一个代表最小子数组和。

上代码:

class Solution {
public:
    int maxAbsoluteSum(vector<int>& nums) {
        vector<int>dp1(nums.size()+1,0);
        vector<int>dp2(nums.size()+1,0);
        dp1[0]=nums[0];
        dp2[0]=nums[0];
        int ans=max(abs(dp1[0]),abs(dp2[0]));
        for(int i=1;i<nums.size();i++){
            if(dp1[i-1]<=0)
                dp1[i]=nums[i];
            if(dp2[i-1]<=0)
            dp2[i]=dp2[i-1]+nums[i];
            if(dp1[i-1]>0)
            dp1[i]=nums[i]+dp1[i-1];
            if(dp2[i-1]>0)
            dp2[i]=nums[i];
            
            ans=max(ans,max(abs(dp1[i]),abs(dp2[i])));
        }
        return ans;
    }
};

相关推荐

  1. leetcode 1749.任意绝对值

    2024-05-12 07:52:05       10 阅读
  2. leetcode 918.环形

    2024-05-12 07:52:05       11 阅读
  3. LeetCode-410.分割

    2024-05-12 07:52:05       35 阅读
  4. LeetCode: 2779. 美丽

    2024-05-12 07:52:05       8 阅读
  5. LeetCode[53]

    2024-05-12 07:52:05       39 阅读
  6. LeetCode 53

    2024-05-12 07:52:05       39 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-12 07:52:05       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-12 07:52:05       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-12 07:52:05       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-12 07:52:05       18 阅读

热门阅读

  1. PHP类和对象概念及用法

    2024-05-12 07:52:05       9 阅读
  2. C++Primer Plus第三章编程练习4

    2024-05-12 07:52:05       9 阅读
  3. Node.js -- 会话控制

    2024-05-12 07:52:05       8 阅读
  4. iOS 如何让超出父视图的部分响应事件

    2024-05-12 07:52:05       11 阅读
  5. 电商平台遭遇DDOS、CC攻击有什么防护方案

    2024-05-12 07:52:05       9 阅读
  6. Lucene 英文词根处理

    2024-05-12 07:52:05       11 阅读
  7. 十分钟“手撕”内部类+static在内部类的使用

    2024-05-12 07:52:05       11 阅读
  8. react经验15:拖拽排序组件dnd-kit的使用经验

    2024-05-12 07:52:05       9 阅读
  9. vue.js 介绍

    2024-05-12 07:52:05       8 阅读
  10. React Router DOM BrowserRouter

    2024-05-12 07:52:05       10 阅读
  11. Pycharm所有快捷键的使用

    2024-05-12 07:52:05       8 阅读
  12. 【DevOps】Linux 网络命令netstat详解

    2024-05-12 07:52:05       12 阅读
  13. ensp简单ac+ap+sta无线配置和脚本

    2024-05-12 07:52:05       8 阅读