​LeetCode解法汇总1186. 删除一次得到子数组最大和

news/2024/7/3 0:43:57

 目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣


描述:

给你一个整数数组,返回它的某个 非空 子数组(连续元素)在执行一次可选的删除操作后,所能得到的最大元素总和。换句话说,你可以从原数组中选出一个子数组,并可以决定要不要从中删除一个元素(只能删一次哦),(删除后)子数组中至少应当有一个元素,然后该子数组(剩下)的元素总和是所有子数组之中最大的。

注意,删除一个元素后,子数组 不能为空

示例 1:

输入:arr = [1,-2,0,3]
输出:4
解释:我们可以选出 [1, -2, 0, 3],然后删掉 -2,这样得到 [1, 0, 3],和最大。

示例 2:

输入:arr = [1,-2,-2,3]
输出:3
解释:我们直接选出 [3],这就是最大和。

示例 3:

输入:arr = [-1,-1,-1,-1]
输出:-1
解释:最后得到的子数组不能为空,所以我们不能选择 [-1] 并从中删去 -1 来得到 0。
     我们应该直接选择 [-1],或者选择 [-1, -1] 再从中删去一个 -1。

提示:

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

解题思路:

* 解题思路:

* 这题看题解的。核心就是动态规划:

* 分别构造两个数组,

* 数组1:一个都不减时,最大的连续数组之和

* 数组2:减1个时,最大的连续数组之和

 

代码:

class Solution1186
{
public:
    int maximumSum(vector<int> &arr)
    {
        int length = arr.size();
        // 不删时,最大连续和
        vector<int> prefixSum0(length + 1);
        // 删1个时,最大连续和
        vector<int> prefixSum1(length + 1);
        prefixSum0[0] = arr[0];
        prefixSum1[0] = 0;
        int abs = prefixSum0[0];
        for (int i = 1; i < length; i++)
        {
            prefixSum0[i] = prefixSum0[i - 1] <= 0 ? arr[i] : prefixSum0[i - 1] + arr[i];
            prefixSum1[i] = prefixSum0[i - 1] > prefixSum1[i - 1] + arr[i] ? prefixSum0[i - 1] : prefixSum1[i - 1] + arr[i];
            int max = prefixSum0[i] > prefixSum1[i] ? prefixSum0[i] : prefixSum1[i];
            abs = max > abs ? max : abs;
        }
        return abs;
    }
};


http://lihuaxi.xjx100.cn/news/1288473.html

相关文章

Linux系统的目录结构与基本命令

目录 Linux系统使用注意 Linux严格区分大小写 Linux文件"扩展名" Linux系统中常见的后缀名称&#xff1a; Linux中所有内容以文件形式保存 Linux中存储设备都必须在挂载之后才能使用 Linux系统的目录结构 Linux分区与Windows分区 Linux系统文件架构 Linux系…

[Flink]wordcount

一、有界流 1、代码 package wc;import org.apache.flink.api.common.functions.FlatMapFunction; import org.apache.flink.api.java.functions.KeySelector; import org.apache.flink.api.java.tuple.Tuple2; import org.apache.flink.streaming.api.datastream.DataStream…

44 # 流的原理

通过 fs 模块实现拷贝功能 同步的拷贝实现 新建 name.txt 文件&#xff0c;里面添加 凯小默的博客const fs require("fs"); const path require("path"); // 读取默认不指定编码都是 buffer 类型 let r fs.readFileSync(path.resolve(__dirname, &qu…

【什么是iMessage苹果推】怎样来获取设备令牌(Device Token)实现步骤

要获取设备令牌&#xff08;Device Token&#xff09;&#xff0c;您需要在应用程序中实现以下步骤&#xff1a; 在应用程序中请求用户授权&#xff1a;您需要请求用户授权允许应用程序发送远程通知。这可以通过使用 UNUserNotificationCenter&#xff08;User Notifications …

Python 按照shp行政边界切割tif的两种方式

介绍两种按照shp行政边界切割tif文件的方式 1. gdal.Warp from osgeo import gdalshp_path"shp文件路径" path"tif数据路径"#读取shp shp_dataset gdal.OpenEx(shp_path, gdal.OF_VECTOR) shp_layer shp_dataset.GetLayer() shp_srs shp_layer.GetSpat…

态路小课堂丨关于单纤双向CWDM波分复用的简介

TARLUZ态路 随着数据中心规模的增长和传输距离的增加&#xff0c;单模光纤传输技术被引入数据中心&#xff0c;同时被引入的还有WDM技术。由于数据中心对其成本较为敏感&#xff0c;因此&#xff0c;CWDM传输技术成为了其更好的选择。在CWDM系统中&#xff0c;主要有双纤单向CW…

linux-2.6.22.6内核总线设备驱动模型

开发一个驱动程序时&#xff0c;不免涉及到对硬件的相关操作&#xff0c;例如读取寄存器和引脚&#xff0c;在不利用任何框架的基础上&#xff0c;硬件代码总是和其他操作耦合到一块&#xff0c;这样做的坏处是代码耦合性太强&#xff0c;例如有三盏led灯&#xff0c;驱动程序每…

Python中的for循环语句及其应用举例(等差数列求和、阶乘、寻找最大值)

Python中的for循环语句及其应用举例(等差数列求和、阶乘、寻找最大值) 在学习任何编程语言的时候&#xff0c;不熟悉判断选择结构和循环结构&#xff0c;就难以发挥计算机优秀的计算能力和提高学习工作效率。本文将重点讲解Python中的for循环语句&#xff0c;并举例等差数列求…