时间:2021-05-19
问题描述:一个有n个元素的数组,这n个元素可以是正数也可以是负数,求最大子数组的和。
方法1:蛮力法
思路:最简单也是最容易想到的方法就是找出所有子数组,然后求所有子数组的和,在所有子数组的和中取最大值。
/** * 方法1(蛮力法):两次循环求最大子数组之和 */ public static int maxSubArray1(int[] a){ int i,j; int ThisSum=0; int MaxSum=0; for (i = 0; i < a.length; i++) { ThisSum=a[i]; for(j=i+1;j<a.length;j++){ ThisSum+=a[j]; if(ThisSum>MaxSum){ MaxSum=ThisSum; } } } return MaxSum; }方法2:优化的动态规划
思路:首先可以根据数组的最后一个元素a[n-1]与最大子数组的关系分为以下三种情况:
1) 最大子数组包含a[n-1],即以a[n-1]结尾。
2) a[n-1]单独构成最大子数组。
3) 最大子数组不包含a[n-1],那么求a[1,...,n-1]的最大子数组可以转换为求a[1,...,n-2]的最大子数组。
通过上述分析可以得出如下结论:假设已经计算出(a[0],...a[i-1])最大的一段数组和为All[i-1],同时也计算出(a[0],...a[i-1])中包含a[i-1]的最大的一段数组和为End[i-1],
则可以得出如下关系:All[i-1]=max{a[i-1],End[i-1],All[i-1]}。利用这个公式和动态规划的思想解决问题。(代码中还解决了起始位置,终止位置的问题)
/** * 方法2:优化的动态规划方法 * nEnd就是通过“数组依次相加加到a[i],然后与a[i]做比较”得来的,保存较大的。因为如果前面的数加到a[i] * 还没有a[i]本身大,那么前面的数也就对最大子数组和没有贡献。厉害 * nAll就是记录一下之前的新得到的nEnd和自身之前谁更大 */ public static int max(int m,int n){ return m>n?m:n; } public static int maxSubArray2(int[] a){ int nAll=a[0];//有n个数字数组的最大子数组之和 int nEnd=a[0];//有n个数字数组包含最后一个元素的子数组的最大和 for (int i = 1; i < a.length; i++) { nEnd=max(nEnd+a[i],a[i]); nAll=max(nEnd, nAll); } return nAll; } private static int begin=0; private static int end=0; /** * 求出最大子数组的开始begin,结尾end,以及整个子数组 */ public static int maxSubArray3(int[] a){ int maxSum=Integer.MIN_VALUE; int nSum=0; int nStart=0; for (int i = 0; i < a.length; i++) { if(nSum<0){ nSum=a[i]; nStart=i; } else{ nSum+=a[i]; } if(nSum>maxSum){ maxSum=nSum; begin=nStart; end=i; } } return maxSum; }以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C语言求连续最大子数组和的方法,是非常实用的技巧。分享给大家供大家参考。具体实现方法如下:#includeusingnamespacestd;in
本文实例讲述了PHP实现求连续子数组最大和问题2种解决方法。分享给大家供大家参考,具体如下:问题描述求子数组的最大和题目描述:输入一个整形数组,数组里有正数也有
问题:求一个M*N的矩阵的最大子矩阵和。比如在如下这个矩阵中:0-2-7092-62-41-41-180-2拥有最大和的子矩阵为:92-41-18其和为15。思
php实现正负数数组最大子序列,要求给出数组,该数组由正负数字组成,找出该数组中连续元素组成的子数组的最大值。这其实得算是个背包变种吧。复制代码代码如下:
一、问题描述1、求一个无序数组的中位数,(若数组是偶数,则中位数是指中间两个数字之和除以2,若数组是奇数,则中位数是指最中间位置。要求:不能使用排序,时间复杂度