当前位置: 首页 > news >正文

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

【LetMeFly】1749.任意子数组和的绝对值的最大值

力扣题目链接:https://leetcode.cn/problems/maximum-absolute-sum-of-any-subarray/

给你一个整数数组 nums 。一个子数组 [numsl, numsl+1, ..., numsr-1, numsr] 的 和的绝对值 为 abs(numsl + numsl+1 + ... + numsr-1 + numsr) 。

请你找出 nums 中 和的绝对值 最大的任意子数组(可能为空),并返回该 最大值 。

abs(x) 定义如下:

  • 如果 x 是负整数,那么 abs(x) = -x 。
  • 如果 x 是非负整数,那么 abs(x) = x 。

 

示例 1:

输入:nums = [1,-3,2,3,-4]
输出:5
解释:子数组 [2,3] 和的绝对值最大,为 abs(2+3) = abs(5) = 5 。

示例 2:

输入:nums = [2,-5,1,-4,3,-2]
输出:8
解释:子数组 [-5,1,-4] 和的绝对值最大,为 abs(-5+1-4) = abs(-8) = 8 。

 

提示:

  • 1 <= nums.length <= 105
  • -104 <= nums[i] <= 104

方法一:动态规划

首先想数组的最大子数组怎么求

遍历数组,使用一个变量 M M M记录以当前元素结尾时的最大子数组。

M = m a x ( n u m s [ i ] , M + n u m s [ i ] ) M = max(nums[i], M + nums[i]) M=max(nums[i],M+nums[i])

可以只选择当前元素,也可以和前面的元素连起来。

接着想子数组的最大和绝对值怎么求

max ⁡ ( a b s ( s u b a r r a y ) ) = m a x ( m a x ( s u b a r r a y ) , − m i n ( s u b a r r a y ) ) \max(abs(subarray)) = max(max(subarray), -min(subarray)) max(abs(subarray))=max(max(subarray),min(subarray))

最大的和的绝对值 要么等于 最大和 要么等于 最小和的相反数。

  • 时间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++

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

Python

# from typing import Listclass Solution:def maxAbsoluteSum(self, nums: List[int]) -> int:ans, m, M = abs(nums[0]), nums[0], nums[0]for i in range(1, len(nums)):M = max(nums[i], M + nums[i])m = min(nums[i], m + nums[i])ans = max(ans, M, -m)return ans

同步发文于CSDN,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/132158662

http://www.lryc.cn/news/118587.html

相关文章:

  • 初学HTML:在线简易画板设计。
  • IDEA项目实践——Spring框架简介,以及IOC注解
  • Scala(第一章Scala入门)
  • Linux tcpdump 命令详解
  • 试卷擦除答案的工具,几个步骤轻松搞定
  • vue3部署宝塔后请求接口404以及刷新页面404的问题解决方案
  • java.sql.Date java.util.Date
  • 斗象科技-2023攻防演练必修高危漏洞集合百度网盘下载(2版本)
  • 分布式数据库视角下的存储过程
  • 深度学习常用的激活函数
  • 深度学习之用PyTorch实现逻辑回归
  • 04-4_Qt 5.9 C++开发指南_时间日期与定时器
  • 7个顶级开源数据集来训练自然语言处理(NLP)和文本模型
  • 计算机网络 网络层 边界网关协议BGP
  • GitHub上受欢迎的Android UI Library
  • cpm log2((cpm/10) + 1) nmf 1e6 1e5
  • 竞赛项目 深度学习的视频多目标跟踪实现
  • 如何避免用waveformRecord复制数组
  • RocketMQ 延迟消息
  • Dex文件混淆(一):BlackObfuscator
  • Linux下编译arm 32 出错(/bin/bash: arm-none-linux-gnueabi-gcc: command not found )
  • 最近遇到的两个小问题总结:git问题和node问题
  • Java # Spring(1)
  • SCL更换阿里数据源
  • 【web逆向】全报文加密流量的去加密测试方案
  • Django实现音乐网站 ⑼
  • 【脚踢数据结构】
  • uni-app使用vue语法进行开发注意事项
  • 数据结构---B树
  • c++11以后c++标准库定义的固定位宽的整数类型(Fixed width integer types)