这篇文章主要介绍了python如何求数组连续最大和的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
题目描述:
一个有 n 个元素的数组,这 n 个元素既可以是正数也可以是负数,数组中连续的一个或多个元素可以组成一个连续的子数组,一个数组可能有多个这种连续的子数组,求子数组的最大值。例如,对于数组 [1,-2,4,8,-4,7,-1,-5] 而言,其最大和的子数组为 [4,8,-4,7],最大值为 15。
方法:
蛮力法
重复利用已经计算的子数组和
动态规划
优化的动态规划
1.蛮力法
找出所有的子数组,然后求出子数组的和,在所有子数组的和中取最大值。
代码实现:
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # @Time : 2020/1/29 21:59 # @Author : buu # @Software: PyCharm # @Blog :https://blog.csdn.net/weixin_44321080 def maxSubArrSum(arr): if arr == None or len(arr) maxSum: maxSum = thisSum j += 1 i += 1 return maxSum if __name__ == '__main__': arr = [1, -2, 4, 8, -4, 7, -1, -5] print('1 max sub array sum:', maxSubArrSum(arr))
结果:
算法性能分析:
这种方法的时间复杂度为O(n3);
2.重复利用已经计算的子数组和
由于 sum[i,j] = sum[i,j-1] + arr[j],在计算 sum[i,j] 的时候可以使用前面已计算出的 sum[i,j-1] 而不需要重新计算,采用这种方法可以省去计算 sum[i,j-1] 的时间,从而提高效率。
代码实现:
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # @Time : 2020/1/30 10:53 # @Author : buu # @Software: PyCharm # @Blog :https://blog.csdn.net/weixin_44321080 def maxSubArrSum(arr): if arr == None or len(arr) maxSum: # 每加一次就判断一次 maxSum = sums j += 1 i += 1 return maxSum if __name__ == '__main__': arr = [1, -2, 4, 8, -4, 7, -1, -5] print('2 max sub array sum:', maxSubArrSum(arr))
结果:
算法性能分析:
使用了双重循环,时间复杂度为O(n2);
3.动态规划
首先可以根据数组最后一个元素 arr[n-1] 与最大子数组的关系分为以下三种情况讨论:
(包含或不包含,包含的话肯定以最后一个元素结尾;不包含的话,或者最后一个元素单独构成最大子数组,或者转换为求 arr[1…n-2] 的最大子数组)
(1) 最大子数组包含 arr[n-1],即最大子数组以 arr[n-1] 结尾;
(2) arr[n-1] 单独构成最大子数组;
(3) 最大子数组不包含 arr[n-1],那么求 arr[1…n-1] 的最大子数组可以转换为求 arr[1…n-2] 的最大子数组。
所以有:
代码实现:
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # @Time : 2020/1/30 11:19 # @Author : buu # @Software: PyCharm # @Blog :https://blog.csdn.net/weixin_44321080 def maxSubArrSum(arr): if arr == None or len(arr)
结果:
算法性能分析:
时间复杂度为O(n);
由于额外申请了两个数组,所以空间复杂度为O(n);
4.优化的动态规划
方法3中每次其实只用到了 End[i-1] 与 All[i-1] ,而不是整个数组中的值,所以可以定义两个变量来保存 End[i-1] 与 All[i-1] 的值,并且可以反复利用。
代码实现:
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # @Time : 2020/1/30 11:55 # @Author : buu # @Software: PyCharm # @Blog :https://blog.csdn.net/weixin_44321080 def maxSubArrSum(arr): if arr == None or len(arr)
结果:
算法性能分析:
时间复杂度为O(n);
空间复杂度为O(1);
引申:
在知道了子数组的最大值后,如何确定最大子数组的和?
思路:
代码实现:
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # @Time : 2020/1/30 12:01 # @A上一篇:Pytorch抽取网络层的Feature Map(Vgg)实例下一篇:Python实现对adb命令封装 热门搜索:
求子数组的最大和
python最大公约数和最小公倍数代码
连续求和
的示例代码
最大连续
相关文章
python如何求数组连续最大和的示例代码
2021-09-10阅读(2997)评论(0)推荐()这篇文章主要介绍了python如何求数组连续最大和的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小...
python求最大连续子数组的和
2021-11-04阅读(6166)评论(0)推荐()这篇文章主要介绍了python求最大连续子数组的和,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
如何求连续几个数之和的最大值
2021-10-05阅读(7525)评论(0)推荐()本篇文章是对如何求连续几个数之和的最大值进行了详细的分析介绍,需要的朋友参考下
golang求连续子数组的最大和实例
2021-09-14阅读(7643)评论(0)推荐()这篇文章主要介绍了golang求连续子数组的最大和实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
求子数组最大和的实例代码
2021-10-05阅读(5353)评论(0)推荐()求子数组最大和的实例代码,需要的朋友可以参考一下
javascript中数组中求最大值示例代码
2021-09-22阅读(5409)评论(0)推荐()数组如何求最大值,想必很多的朋友都不会吧,本文为大家介绍下javascript中数组是如何求最大值的,感兴趣的朋友不要错过
分享JS数组求和与求最大值的方法
2021-10-10阅读(6562)评论(0)推荐()数组求和在项目需求中还是挺常见的,比如购物车金额统计、人员的前台统计等等。今天小编先是给大家分享了JS数组求和的两个方法,而后又用实例演示js数组求和,并求出数...
取消
提交评论
© 2021 编程之家
工信部备案号:琼ICP备2022000316号
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。