算法的学习笔记—连续子数组的最大和

img

😀前言
在算法问题中,求解连续子数组的最大和是一个经典问题。给定一个整数数组,找到一个连续的子数组,使得其元素之和最大。本文将详细讲解如何解决这个问题,并提供Java实现代码。

🏠个人主页:尘觉主页

文章目录

  • 🥰连续子数组的最大和
    • 😀问题描述
    • 😊解题思路
    • 💞Java实现
    • 😊代码详解
      • 💞复杂度分析
    • 😄总结

🥰连续子数组的最大和

😀问题描述

我们有一个整数数组,例如 {6, -3, -2, 7, -15, 1, 2, 2}。在这个数组中,连续子数组的最大和为 8(从第0个元素到第3个元素)。

😊解题思路

这个问题可以使用动态规划的思路来解决。具体来说,我们可以通过遍历数组并在遍历的过程中计算出当前子数组的和。如果当前子数组的和是负数,那么我们就从下一个元素重新开始计算子数组的和;否则,我们继续累加当前的元素值。同时,我们在遍历的过程中,不断更新最大子数组和的值。

步骤总结:

  1. 初始化两个变量:greatestSum 用来存储当前最大的子数组和,sum 用来存储当前子数组的和。
  2. 遍历数组中的每个元素:
    • 如果当前的 sum 为负数,重新开始计算,即将当前元素赋值给 sum
    • 否则,将当前元素的值累加到 sum 中。
    • 在每次累加后,更新 greatestSum,确保它始终是最大子数组和。
  3. 遍历完成后,greatestSum 就是所求的连续子数组的最大和。

💞Java实现

下面是使用上述思路的Java代码实现:

public int FindGreatestSumOfSubArray(int[] nums) {// 检查输入数组是否为空或者长度为零if (nums == null || nums.length == 0)return 0;// 初始化最大子数组和为负无穷大int greatestSum = Integer.MIN_VALUE;// 初始化当前子数组的和为0int sum = 0;// 遍历数组中的每一个元素for (int val : nums) {// 如果当前子数组的和为负数,则从当前元素重新开始计算sum = sum <= 0 ? val : sum + val;// 更新最大子数组和greatestSum = Math.max(greatestSum, sum);}// 返回最大子数组和return greatestSum;
}

😊代码详解

  • 数组为空检查:首先,检查输入的数组是否为空或长度为零。如果是,则直接返回0,避免出现空指针异常。
  • 初始化最大子数组和:我们将 greatestSum 初始化为 Integer.MIN_VALUE,这是为了确保即使数组中的所有元素都是负数,我们也能够正确地计算出最大子数组和。
  • 遍历数组:在遍历数组时,我们根据当前子数组的和是否为负数,决定是否重新开始计算子数组的和。如果当前的 sum 是负数,那么直接将 val 赋值给 sum,否则将 val 累加到 sum 中。
  • 更新最大和:每次更新 sum 后,我们使用 Math.max() 方法来更新 greatestSum,确保它总是最大子数组和。

💞复杂度分析

该算法的时间复杂度为O(n),其中n是数组的长度,因为我们只需遍历数组一次。空间复杂度为O(1),因为只使用了常量级别的额外空间。

😄总结

通过上述的动态规划方法,我们能够有效地解决连续子数组的最大和问题。该方法简单易懂,并且具有较高的效率,适合在大多数情况下使用。

😁热门专栏推荐
想学习vue的可以看看这个

java基础合集

数据库合集

redis合集

nginx合集

linux合集

手写机制

微服务组件

spring_尘觉

springMVC

mybits

等等等还有许多优秀的合集在主页等着大家的光顾感谢大家的支持

🤔欢迎大家加入我的社区 尘觉社区

文章到这里就结束了,如果有什么疑问的地方请指出,诸佬们一起来评论区一起讨论😁
希望能和诸佬们一起努力,今后我们一起观看感谢您的阅读🍻
如果帮助到您不妨3连支持一下,创造不易您们的支持是我的动力🤞

img

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

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

相关文章

SpringBoot对接Midjourney Api

提示&#xff1a;SpringBoot对接Midjourney Api 文章目录 目录 文章目录 后端代码 导包 controller层 工具类层 前端代码 申请API 测试结果 后端代码 导包 <!--添加hutool的依赖--><dependency><groupId>cn.hutool</groupId><artifactId&g…

黑神话悟空 PC端配置需求详解:如何为不同游戏体验选择合适的配置?

《黑神话&#xff1a;悟空》是一款备受期待的动作角色扮演游戏&#xff0c;由游戏科学&#xff08;Game Science&#xff09;开发&#xff0c;基于《西游记》改编。随着游戏的发布&#xff0c;许多玩家都在关心一件事&#xff1a;我的电脑能带动这款游戏吗&#xff1f;本文将详…

centos7 xtrabackup mysql(8)压缩 全量备份 还原(4)

centos7 xtrabackup mysql&#xff08;8&#xff09;压缩 全量备份 还原&#xff08;4&#xff09; 查看版本&#xff1a; xtrabackup --version qpress --help 主机端 mysql -u root -p 1234aA~1 use company_pro; insert into employee(name) value (‘20240823_1401’);…

为什么需要对即将上线的系统进行压力测试

摘要 本文将探讨为什么在系统上线前进行压力测试至关重要。我们将通过具体的案例和代码示例来说明压力测试的重要性&#xff0c;并介绍如何执行基本的压力测试。 1. 引言 在软件开发周期中&#xff0c;压力测试是一项关键的质量保证措施。它可以帮助开发者和运维人员评估系统…

应对Nginx负载均衡中的请求超时:策略与配置

在Nginx负载均衡的部署中&#xff0c;处理请求超时是一个关键问题。请求超时不仅影响用户体验&#xff0c;还可能隐藏着后端服务的性能瓶颈。合理配置Nginx以处理超时情况&#xff0c;可以显著提高服务的稳定性和可靠性。本文将详细介绍如何在Nginx负载均衡中处理请求超时&…

MT3608L 2.5A,高效率1.2MHz电流模式升压转换器芯片IC

一般描述 MT3608L是一款恒频、6针SOT23电流模式升压转换器&#xff0c;适用于小型、低功率应用。MT3608L开关频率为1.2 MHz&#xff0c;允许使用高度小于2mm的微型、低成本电容器和电感器。内部软启动可产生小浪涌电流&#xff0c;延长电池寿命。 MT3608L具有在…

Photoshop - summary

Photoshop 移动图层 Ctrl ]&#xff1a;将当前图层移到最顶层&#xff1b; Ctrl [&#xff1a;将当前图层移到最底层&#xff1b; Ctrl Shift ]&#xff1a;将当前图层上移一层&#xff1b; Ctrl Shift [&#xff1a;将当前图层下移一层。

JavaWeb JavaScript ⑥ 事件

你摸黑偷偷赶得路&#xff0c;都会变成意外来袭时你少受的苦 —— 24.8.29 一、什么是事件 HTML 事件可以是浏览器行为&#xff0c;也可以是用户行为。 当一些行为发生时,可以自动触发对应的JS函数的运行,我们称之为事件发生&#xff0c;JS的事 件驱动指的就是行为触发代码运行…

ComfyUI SDXL Prompt Styler 简介

SDXL Prompt Styler 来自于 comfyui-art-venture 节点 style 已经更新 旧版本的 sai-line art 变更为 line art log_prompt 已经更新 旧版本的 false 变更为 Yes 或 No style_name 已经更新 旧版本的 true &#xff08;不再适用&#xff09;&#xff08;可以尝试对应style中…

【IoT】将各类遥控器(红外,频射,蓝牙,wifi,Zigbee)等设备接入米家,实现家庭物联网设备控制(以极米Z7X投影仪为例)

【IoT】将各类遥控器&#xff08;红外&#xff0c;频射&#xff0c;蓝牙&#xff0c;wifi&#xff0c;加密&#xff09;等设备接入米家&#xff0c;实现家庭物联网设备控制&#xff08;以极米Z7X投影仪为例&#xff09; 文章目录 1、三种主流遥控方式&#xff08;红外&#xff…

看新闻知补贴不用专门薅羊毛!让工作变舒服的5个黄金法则——早读(逆天打工人爬取热门微信文章解读)

你们都不看新闻吗&#xff1f; 引言Python 代码第一篇 洞见 让工作变舒服的5个黄金法则第二篇 故事之散户结尾 (发了3000亿以旧换新补贴&#xff0c;大家没有感觉到力度吗&#xff1f; 时间到今年年底&#xff0c;9月-12月是消费区&#xff0c;中间夹杂个双十一&#xff0c;现在…

一文搞懂 js 原型和原型链

文章目录 一、前言二、原型2.1 概念2.2 获取原型的方法2.2.1 __proto__获取方式2.2.2 通过构造函数prototype 属性获取2.2.2 ES6 class 通过Object.getPrototypeOf()获取类原型 2.3 通过原型实现继承2.4 原型的作用 三、 原型链四、ES6实现继承五、综述 一、前言 原型和原型链…

深入学习SQL优化的第五天(最后一天)

子查询 1321 餐 馆 营 业 额 变 化 增 长 1321. 餐馆营业额变化增长 表: Customer------------------------ | Column Name | Type | ------------------------ | customer_id | int | | name | varchar | | visited_on | date | | amount …

k8s Failed to delete cgroup paths

问题 Aug 26 10:29:27 bjm1 systemd[1]: Stopping libcontainer container 6b55a1165ba1f974ee460d84832a4ee1df0ea36899498120c997cce518c2e7e0... Aug 26 10:29:37 bjm1 dockerd[152737]: time="2024-08-26T10:29:37.453518079+08:0

Linux网口指令

一 查看配置 ifconfig 二 修改IP sudo ifconfig ens33 192.168.150.100 netmask 255.255.255.0

GPT应用-如何用GPT4.0写一份专业的ppt

创建一份专业的PPT通常需要花费大量的时间和精力&#xff0c;但使用GPT-4.0&#xff0c;你可以轻松生成高质量的内容&#xff0c;从结构设计到具体的幻灯片内容&#xff0c;GPT-4.0 都能提供帮助。以下是一个详细教程&#xff0c;介绍如何用GPT-4.0 写一份专业的PPT。 1. 明确P…

国内券商有没有提供股票程序化交易接口的

国内券商股票程序化交易接口概述 股票程序化交易在金融市场中日益重要&#xff0c;而国内券商在这方面的服务和接口提供情况备受关注。 券商提供的接口方式 券商提供的接口方式多种多样。有些券商提供自研系统&#xff0c;如国信的云核用 C编程&#xff0c;速度较快但入门门…

kafka的12个重要概念

kafka的12个重要概念 1、服务器broker1.1、Broker 的主要功能1.2、Kafka Broker 的架构1.3、配置和管理1.4、高可用性和负载均衡1.5、总结 2、主题topic2.1、主要特点 3、事件Event4、生产者producer4.1、主要功能4.2、Producer 的配置选项4.3、Producer 的工作流程4.4、总结 5…

如何在不增加太多时间和精力的情况下,提高OZON电商店铺的运营效果

以下是一些在不增加过多时间精力的情况下提高 OZON 电商店铺运营效果的要点&#xff1a; 一、优化产品信息 • 关键词优化&#xff1a;利用 15-30 分钟时间&#xff0c;每周进行一次关键词研究&#xff0c;找到与产品相关且搜索量大的关键词&#xff0c;将其巧妙地融入到产品标…

3、LVGL控件-开关、复选框、进度条

本篇文章目录导航 ♠♠ LVGL控件-开关、复选框、进度条 ♣♣♣♣ 一、LVGL开关部件 ♦♦♦♦♦♦♦♦ 1.1 开关部件组成部分 ♦♦♦♦♦♦♦♦ 1.2 开关部件基本API ♦♦♦♦♦♦♦♦ 1.3 实验小演示 ♣♣♣♣ 二、LVGL复选框部件 ♦♦♦♦♦♦♦♦ 2.1 复选框部件组成部分 ♦…