Kadane 算法 | 53. 最大子数组和 + 918. 环形子数组的最大和

news2024/9/22 11:38:44

目录

    • 1 维基百科
    • 2 53. 最大子数组和
      • 2.1 代码思路
      • 2.2 完整代码
    • 3 918. 环形子数组的最大和
      • 3.1 代码思路
      • 3.2 完整代码




1 维基百科

最大子数组问题

在计算机科学中,最大子数组问题的目标是在数组的一维方向找到一个连续的子数组,使该子数组的和最大。例如,对一个数组 [ − 2 , 1 , − 3 , 4 , − 1 , 2 , 1 , − 5 , 4 ] \mathrm{[−2, 1, −3, 4, −1, 2, 1, −5, 4]} [2,1,3,4,1,2,1,5,4],其连续子数组中和最大的是 [ 4 , − 1 , 2 , 1 ] \mathrm{[4, −1, 2, 1]} [4,1,2,1],其和为 6 \mathrm{6} 6

Kadane 卡丹算法

卡丹算法扫描一次整个数组的所有数值,并在每一个扫描点计算以该点数值为结束点的子数组的最大和。

该子数组由两部分组成:以前一个位置为结束点的最大子数组和、该位置的数值。因为该算法用到了「最佳子结构」(以每个位置为结束点的最大子数组和都是基于其前一位置的最大子数组和计算得出的),该算法可看成动态规划的一个例子。

由于只需要记忆前一位置的最大子数组和,因此不需要定义 d p \mathrm{dp} dp 数组,只需要定义一个变量即可。



2 53. 最大子数组和

2.1 代码思路

思路说明图如下,其中 p r e \mathrm{pre} pre 表示以当前位置为结尾的最大子数组和。已经求得以 i = 2 \mathrm{i=2} i=2 位置为结尾的最大子数组和是 − 2 -2 2,现在需要求解以 i = 3 \mathrm{i=3} i=3 位置为结尾的最大子数组和。如下图所示:

在这里插入图片描述

针对 i = 3 \mathrm{i=3} i=3 位置,它既可以接入前一子数组,也可以另起一个新子数组。由于接入前一子数组的和为 p r e = − 2 + 4 = 2 \mathrm{pre=-2+4=2} pre=2+4=2,而另起一个新子数组的和为 p r e = 4 > 2 \mathrm{pre=4>2} pre=4>2,因此以 i = 3 \mathrm{i=3} i=3 位置为结尾的最大子数组和是 4 \mathrm{4} 4

说明:之所以在图中把已经访问过的位置遮盖起来,是因为我认为没有必要考虑前面位置的子数组长什么样,容易把自己绕晕。除此之外, p r e \mathrm{pre} pre 表示的是「以当前位置为结尾」的最大子数组和,而非最大子数组和。



2.2 完整代码

int maxSubArray(vector<int>& nums) {
  int pre = 0;
  int ans = INT_MIN;
  for (auto & num : nums) {
    pre = max(pre + num, num);
    ans = max(ans, pre);
  }
  return ans;
}


3 918. 环形子数组的最大和

3.1 代码思路

根据题意可得,最大子数组和可能来源于以下两种情况:

在这里插入图片描述

其中「情况一」可以直接用「53. 最大子数组和」的解法进行处理,「情况二」可以理解为「子数组和 = 前缀和 + 后缀和」。我们可以在处理「情况一」的同时顺便计算前缀和,以便「情况二」进行使用。



3.2 完整代码

int maxSubarraySumCircular(vector<int>& nums) {
  int n = nums.size();
  int ans = nums[0];

  // 情况一(同时计算前缀和、最大前缀和)
  int pre = nums[0];
  int preSum = nums[0];
  vector<int> preMax(n);
  preMax[0] = nums[0];
  for (int i = 1; i < n; ++i) {
    pre = max(pre + nums[i], nums[i]);
    ans = max(ans, pre);
    preSum += nums[i];
    preMax[i] = max(preMax[i - 1], preSum);
  }

  // 情况二(计算后缀和)
  int posSum = 0;
  for (int i = n - 1; i > 0; --i) {
    posSum += nums[i];
    ans = max(ans, preMax[i - 1] + posSum);
  }

  return ans;
}

变量说明

  • p r e \mathrm{pre} pre:以 i \mathrm{i} i 位置为结尾的最大子数组和;
  • p r e S u m \mathrm{preSum} preSum:前缀和;
  • p r e M a x \mathrm{preMax} preMax:以 i \mathrm{i} i 位置为结尾的最大前缀和;
  • p o s S u m \mathrm{posSum} posSum:后缀和。

针对「情况二」,由于选用的前缀不能和当前的后缀重叠,因此针对以 i \mathrm{i} i 位置为开头的后缀,它能考虑的最大前缀和是 p r e M a x [ i − 1 ] \mathrm{preMax[i - 1]} preMax[i1]



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1950890.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Axious的请求与响应

Axious的请求与响应 1.什么是Axious Axious是一个开源的可以用在浏览器和Node.js的异步通信框架&#xff0c;它的主要作用就是实现AJAX异步通信&#xff0c;其功能特点如下&#xff1a; 从浏览器中创建XMLHttpRequests ~从node.js创建Http请求 支持PromiseAPI 拦截请求和…

[UVM源代码研究] 聊聊UVM中的callback机制

1. callback机制是什么&#xff1f; 以最高效的方式完成芯片验证&#xff0c;一直以来都是验证人员的首要目标&#xff0c;那么最直接的方式就是环境的移植和重用&#xff0c;一个优秀的验证工程师&#xff0c;在开发环境的过程中&#xff0c;一定会考虑环境的继承和重用。 继…

c++ 智能指针shared_ptr与make_shared

shared_ptr是C11引入的一种智能指针&#xff0c;‌它允许多个shared_ptr实例共享同一个对象&#xff0c;‌通过引用计数来管理对象的生命周期。‌当最后一个持有对象的shared_ptr被销毁时&#xff0c;‌它会自动删除所指向的对象。‌这种智能指针主要用于解决资源管理问题&…

简单小案例分析

一、容器和实例关系 <div class"app"><h1>Hello,{{name}}</h1> </div> <div class"app"><h1>Hello,{{name}}</h1> </div><script>//创建Vue实例new Vue({el:".app", //el用于指定当前V…

北大延毕硕士×INFJ | 我解脱了

前言 拿了双证&#xff0c;我终于能静下心来复盘一下我延毕一年的经历了。 给后面也许有相同困境的朋友们做个参考或者心理疏导作用。 延毕的原因 我延毕的主要原因是论文研三的时候论文没有完成&#xff0c;我们专业的论文一般是6个月全身心投入可以完成。我这个人是典型的…

7月24日JavaSE学习笔记

序列化版本控制 序列化&#xff1a;将内存对象转换成序列&#xff08;流&#xff09;的过程 反序列化&#xff1a;将对象序列读入程序&#xff0c;转换成对象的方式&#xff1b;反序列化的对象是一个新的对象。 serialVersionUID 是一个类的序列化版本号 private static fin…

77.WEB渗透测试-信息收集-框架组件识别利用(1)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;76.WEB渗透测试-信息收集- WAF、框架组件识别&#xff08;16&#xff09; java&#xff…

The Llama 3 Herd of Models.Llama 3 模型论文全文

现代人工智能(AI)系统是由基础模型驱动的。本文提出了一套新的基础模型,称为Llama 3。它是一组语言模型,支持多语言、编码、推理和工具使用。我们最大的模型是一个密集的Transformer,具有405B个参数和多达128K个tokens的上下文窗口。本文对Llama 3进行了广泛的实证评价。我们…

【Django】前端技术HTML常用标签(开发环境vscode)

文章目录 安装两个常用插件HTML常用标签定义文档类型DOCTYPE网页的结构html/head//title/body/div标题h1/h2/h3/h4/h5分割线hr段落 p列表ul/li&#xff0c;ol/li超链接a文本span图片img按钮button表格table&#xff08;table、tr、th、td&#xff09;表单form 安装两个常用插件…

深度学习环境配置——总结下近期遇到的”坑“

文章目录 1. 问题1&#xff1a;硬件选择的误区2. 问题2&#xff1a;操作系统的适配难题3. 问题3&#xff1a;深度学习框架的安装陷阱4. 问题4&#xff1a;CUDA与cuDNN的版本匹配问题5. 问题5&#xff1a;网络配置的瓶颈6. 问题6&#xff1a;数据预处理的技巧7. 问题7&#xff1…

CVPR`24 | 4D编辑哪家强?浙大首次提出通用指导4D编辑框架:Instruct 4D-to-4D

文章链接&#xff1a;https://arxiv.org/pdf/2406.09402 项目地址&#xff1a;https://immortalco.github.io/Instruct-4D-to-4D/ 今天和大家一起学习的是Instruct 4D-to-4D&#xff0c;可以通过2D扩散模型实现4D感知和时空一致性&#xff0c;以生成高质量的指令引导的动态场景…

用户使用算力共享平台流程

目录 用户使用算力共享平台流程 一、用户注册与认证 二、接入算力资源 三、任务发布与管理 四、商业调度与资源分配 五、任务执行与结果验证 六、支付与结算 七、评价与信誉建立 算力架构概述 “以案赋能” | 首届“华彩杯”算力应用创新大赛全国总决赛获奖案例选编

【JUC】Java锁介绍

文章目录 阿里锁开发规范乐观锁和悲观锁悲观锁乐观锁 synchronized 类锁、对象锁synchronized有三种应用方式锁相关的8种案例演示&#xff08;对象锁、类锁&#xff09;标准访问ab两个线程&#xff0c;请问先打印邮件还是短信&#xff1f;sendEmail钟加入暂停3秒钟&#xff0c;…

【Python机器学习】决策树的构造——递归构建决策树

我们可以采用递归的原则处理数据集&#xff0c;递归结束的条件是&#xff1a;程序遍历完所有划分数据集的属性&#xff0c;或者每个分支下的所有实例都具有相同的分类。如果所有实例具有相同的分类&#xff0c;则得到一个叶子节点或者终止块。任何到达叶子节点的数据必然属于叶…

软考:软件设计师 — 7.软件工程

七. 软件工程 1. 软件工程概述 &#xff08;1&#xff09;软件生存周期 &#xff08;2&#xff09;软件过程 软件开发中所遵循的路线图称为 "软件过程"。 针对管理软件开发的整个过程&#xff0c;提出了两个模型&#xff1a;能力成熟度模型&#xff08;CMM&#…

uniapp引入自定义图标

目录 一、选择图标&#xff0c;加入购物车 二、下载到本地 三、导入项目 四、修改字体引用路径 五、开始使用 这里以扩展iconfont图标为例 官网&#xff1a;iconfont-阿里巴巴矢量图标库 一、选择图标&#xff0c;加入购物车 二、下载到本地 直接点击下载素材&#xff0…

mysql中You can’t specify target table for update in FROM clause错误

mysql中You can’t specify target table for update in FROM clause错误 You cannot update a table and select directly from the same table in a subquery. mysql官网中有这句话&#xff0c;我们不能在一个语句中先在子查询中从某张表查出一些值&#xff0c;再update这张表…

matplotlib 画图函数,最常用的

并排显示2个图片 import os import numpy as np from PIL import Image import matplotlib.pyplot as pltimage1 Image.open(a.png) image2 Image.open(a2.png)# Create a figure with two subplots (1 row, 2 columns) fig, axes plt.subplots(1, 2, figsize(10, 5))# Di…

使用Log4Net和中间件记录接口访问日志

一、功能概述 Log4Net log4net 是一个用于.NET应用程序的日志记录框架。它允许开发人员在他们的应用程序中记录各种信息&#xff0c;以便追踪应用程序的运行状态、排查问题和分析性能。log4net的主要作用包括&#xff1a; 日志记录: 记录应用程序的运行时信息&#xff0c;如调…

【单片机毕业设计选题24081】-路灯无线数据采集器

系统功能: 手机开启2.4G WiFi热点后再给系统上电 系统操作说明&#xff1a; 上电后OLED显示 “欢迎使用智能路灯系统请稍后”&#xff0c;两秒后显示Connecting...表示 正在连接阿里云&#xff0c;正常连接阿里云后显示第一页面&#xff0c;如长时间显示Connecting...请 检…