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

【LeetCode每日一题】53. 最大子数组和

https://leetcode.cn/problems/maximum-subarray/description/

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组 是数组中的一个连续部分。

方式一:暴力解法(超时)

先算出数组的前缀和,然后通过2个for循环遍历出所有的连续子数组。

/*** @param {number[]} nums* @return {number}*/
var maxSubArray = function(nums) {let prefixArr = [];let sum = 0;for(let num of nums){sum += num;prefixArr.push(sum);}prefixArr.unshift(0);// let max = prefixArr[0];let max = -Infinityfor(let i = 0; i < prefixArr.length-1; i++){for(let j = i+1 ; j < prefixArr.length; j++){max = Math.max(max, prefixArr[j] - prefixArr[i]);}}return max;
}

方式二:

寻找一个具有最大和的连续子数组,算出以每个元素结尾的最大和,在这些最大值里求最大值。

对于元素A来说,以它结束的最大值 = Math.max(元素A,元素A+前一个元素的最大值)

遍历,求出以每个元素结尾的最大值放在一个数组。

求该数组的最大值。

/*** @param {number[]} nums* @return {number}*/
var maxSubArray = function(nums) {let max = 0let arr = []**for(**let num of nums){max = Math.max(max+num, num);arr.push(max)}return Math.max(...arr);
};

根据方式二,可以在遍历的时候将数据就进行比较。

/*** @param {number[]} nums* @return {number}*/
var maxSubArray = function(nums) {let res = nums[0];let max = 0for(let num of nums){max = Math.max(max+num, num);res = Math.max(res, max);}return res;
};
http://www.lryc.cn/news/259420.html

相关文章:

  • 机器学习笔记 什么是协方差矩阵?
  • 使用Python监控服务器在线状态
  • 【JAVA】黑马MybatisPlus 学习笔记【二】【核心功能】
  • 区块链实验室(30) - 区块链期刊:Distributed Ledger Technologies: Research and Practice
  • Nginx【通俗易懂】《中篇》
  • 组件的二次封装
  • curl+postman 在java开发中的使用(提高效率)
  • 【电子取证:FTK IMAGER 篇】DD、E01系统镜像动态仿真
  • netcat瑞士军刀
  • 【征稿倒计时十天】第三届高性能计算与通信工程国际学术会议(HPCCE 2023)
  • 编程应用实际场景:台球厅怎么样用电脑给客人计时,台球计时收费系统操作教程
  • 云计算大屏,可视化云计算分析平台(云实时数据大屏PSD源文件)
  • 高频js-----js执行机制 Event Loop
  • 恢复出厂设置后在 Android 上恢复照片的 6 种常用方法
  • 人工智能_机器学习065_SVM支持向量机KKT条件_深度理解KKT条件下的损失函数求解过程_公式详细推导_---人工智能工作笔记0105
  • 网线市场现状与发展趋势预测
  • 力扣二叉树--第四十一天
  • 计算机视觉(P2)-计算机视觉任务和应用
  • redis-学习笔记(Jedis zset 简单命令)
  • uniapp实战 —— 弹出层 uni-popup (含vue3子组件调父组件的方法)
  • 智能优化算法应用:基于平衡优化器算法3D无线传感器网络(WSN)覆盖优化 - 附代码
  • Netty详细文档
  • C语言结构体和位段
  • 【剑指offer|图解|数组】寻找文件副本 + 螺旋遍历二维数组
  • Python核心编程之文件和输入输出
  • Axure 9基本元件,表单及表格元件简介,表单案例
  • ARM I2C通信
  • Cent OS7 磁盘挂载:扩展存储空间和自动挂载
  • 《使用ThinkPHP6开发项目》 - 创建应用
  • SpringBoot进行自然语言处理,利用Hanlp进行文本情感分析