全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

求最大子数组之和的方法解析(2种可选)

问题描述:一个有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;
 }

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# 最大  # 子数组  #   # php数组函数序列之array_sum() - 计算数组元素值之和  # C语言求连续最大子数组和的方法  # 求子数组最大和的解决方法详解  # 求子数组最大和的实例代码  # 求出  # 计算出  # 还没有  # 更大  # 两次  # 三种  # 解决问题  # 则可  # 可以根据  # 就对  # 最简单  # 最容易  # 得来  # 即以  # 大和  # 中取  # 不包含  # 为求  # 解决了  # 分为以下 


相关文章: 专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  高性价比服务器租赁——企业级配置与24小时运维服务  如何获取开源自助建站系统免费下载链接?  建站之星代理费用多少?最新价格详情介绍  建站之星展会模板:智能建站与自助搭建高效解决方案  如何使用Golang安装API文档生成工具_快速生成接口文档  建站之星后台密码遗忘?如何快速找回?  建站之星如何取消后台验证码生成?  网站制作服务平台,有什么网站可以发布本地服务信息?  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  高端企业智能建站程序:SEO优化与响应式模板定制开发  岳西云建站教程与模板下载_一站式快速建站系统操作指南  如何通过万网虚拟主机快速搭建网站?  网站网页制作专业公司,怎样制作自己的网页?  如何在橙子建站上传落地页?操作指南详解  北京建设网站制作公司,北京古代建筑博物馆预约官网?  如何通过可视化优化提升建站效果?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  湖北网站制作公司有哪些,湖北清能集团官网?  linux top下的 minerd 木马清除方法  表情包在线制作网站免费,表情包怎么弄?  PHP 500报错的快速解决方法  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  南宁网站建设制作定制,南宁网站建设可以定制吗?  如何在云虚拟主机上快速搭建个人网站?  已有域名和空间如何快速搭建网站?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  建站主机SSH密钥生成步骤及常见问题解答?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  javascript中的try catch异常捕获机制用法分析  浅谈Javascript中的Label语句  子杰智能建站系统|零代码开发与AI生成SEO优化指南  佛山企业网站制作公司有哪些,沟通100网上服务官网?  如何快速上传建站程序避免常见错误?  建站主机如何选?高性价比方案全解析  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  如何有效防御Web建站篡改攻击?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  建站VPS选购需注意哪些关键参数?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】  建站之星如何快速解决建站难题?  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  b2c电商网站制作流程,b2c水平综合的电商平台?  建站主机功能解析:服务器选择与快速搭建指南  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  重庆市网站制作公司,重庆招聘网站哪个好?  如何快速搭建高效香港服务器网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。