博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【算法】LeetCode算法题-Maximum Subarray
阅读量:5952 次
发布时间:2019-06-19

本文共 2053 字,大约阅读时间需要 6 分钟。

这是悦乐书的第154次更新,第156篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第13题(顺位题号是53)。给定一个整数数组nums,找出一个最大和,此和是由数组中索引连续的元素组成,至少包含一个元素。例如:

输入:[-2, 1, -3, 4, -1, 2, 1, -5,4]

输出:6
说明:[4,-1,2,1]具有最大的和为6

输入:[1, 2, 3]

输出:6
说明:[1, 2, 3]具有最大的和为6

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

因为本题最后输出的是最大值,所以需要进行求和,并且要从第一位元素开始,依次和相邻元素相加来判断。

第一次循环,得到数组第一个元素,与0相加,此时最大值是元素本身。

第二次循环,得到数组第二个元素,与第一个元素相加,此时相加的和需要先判断是否大于第二个元素本身,因为如果两个数的和还没有本身大,那么此时最大和就是第二个元素本身。其次,还要和上一个和判断,如果大于第一次循环得到的和,那么新的最大和即为第一个元素和第二个元素之和或者第二个元素本身;反之最大和依旧是第一次循环后的最大和。

后面的循环与上面一致,最开始第一次的循环也是如此,为了方便对比,只是详细说明了第二次循环的处理逻辑。

public int maxSubArray(int[] nums) {    int sum = 0;    int max = Integer.MIN_VALUE;    for (int i = 0; i < nums.length; i++) {        sum += nums[i];        if (nums[i] > sum) {            sum = nums[i];        }        if (sum > max) {            max = sum;        }    }    return max;}

对于上面的代码,我们还可以再简化下。

public int maxSubArray2(int[] nums) {    int result = Integer.MIN_VALUE;    int sum = 0;    for (int i = 0; i < nums.length; i++) {        sum = Math.max(nums[i] + sum, nums[i]);        result = Math.max(result, sum);    }    return result;}

03 第二种解法

还有一种思路,就是分而治之,将大问题拆分成小问题,找到小问题的答案后,最后合在一起再得出最后的答案。下面的代码是讨论区里某位大神的,可以好好看下。

public int maxSubArray3(int[] a) {    return helper(a, 0, a.length - 1);}int helper(int[] a, int l, int r) {    if(l > r) return Integer.MIN_VALUE;    if(l == r) return a[l];    int mid = l + (r - l)/2;    return Math.max(crossMidMax(a, l, r), Math.max(helper(a, l, mid - 1), helper(a, mid + 1, r)));}int crossMidMax(int[] a, int l, int r) {    int mid = l + (r - l)/2;    int lmax = a[mid], lg =  a[mid];    for(int i = mid -1; i >= l; i--) {        lmax += a[i];        lg = Math.max(lmax, lg);    }    int rmax = a[mid], rg =  a[mid];    for(int i = mid +1; i <= r; i++) {        rmax += a[i];        rg = Math.max(rmax, rg);    }    return lg + rg - a[mid];}

04 小结

今天此题涉及的分而治之算法,会写在后面的算法和数据结构的理论知识介绍中,研究透彻了再和各位分享。以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

转载于:https://www.cnblogs.com/xiaochuan94/p/9864536.html

你可能感兴趣的文章
log4j配置文件说明
查看>>
Maven: 为Compiler插件设置source和target版本
查看>>
linux下永久添加静态路由
查看>>
android 全局变量和局部变量命名规则
查看>>
Ubuntu Sub-process /usr/bin/dpkg
查看>>
详解DNS的常用记录(下):DNS系列之三
查看>>
linux的日志服务器关于屏蔽一些关键字的方法
查看>>
事情的两面性
查看>>
只要会营销,shi都能卖出去?
查看>>
sed单行处理命令奇偶行输出
查看>>
走向DBA[MSSQL篇] 从SQL语句的角度 提高数据库的访问性能
查看>>
VC++深入详解学习笔记1
查看>>
安装配置discuz
查看>>
CentOS7 64位小型操作系统的安装
查看>>
线程互互斥锁
查看>>
KVM虚拟机&openVSwitch杂记(1)
查看>>
win7下ActiveX注册错误0x80040200解决参考
查看>>
《.NET应用架构设计:原则、模式与实践》新书博客--试读-1.1-正确认识软件架构...
查看>>
网址收藏
查看>>
2013 Linux领域年终盘点
查看>>