博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
连续子数组的最大的和
阅读量:4331 次
发布时间:2019-06-06

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

HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。你会不会被他忽悠住?

思路:先一直求和,和最大值比较,并赋予最大值。若最大值开始减小,则当最大值减小到0时,重新将求和值赋为0。(因为从此时之前的数字不可能有最大值。需要重新求和)

public int FindGreatestSumOfSubArray(int[] array) {         if(array.length == 0) return 0; //异常情况        int max = array[0]; //不能赋为0,有可能为负值        int sum = 0;        for(int i=0;i
max){ max = sum; } if(sum <= 0){ sum = 0; } } return max; }

 

转载于:https://www.cnblogs.com/yingpu/p/5813898.html

你可能感兴趣的文章
单工、半双工和全双工的定义
查看>>
Hdu【线段树】基础题.cpp
查看>>
时钟系统
查看>>
BiTree
查看>>
5个基于HTML5的加载动画推荐
查看>>
水平权限漏洞的修复方案
查看>>
静态链接与动态链接的区别
查看>>
Android 关于悬浮窗权限的问题
查看>>
如何使用mysql
查看>>
linux下wc命令详解
查看>>
敏捷开发中软件测试团队的职责和产出是什么?
查看>>
在mvc3中使用ffmpeg对上传视频进行截图和转换格式
查看>>
python的字符串内建函数
查看>>
Spring - DI
查看>>
微软自己的官网介绍 SSL 参数相关
查看>>
Composite UI Application Block (CAB) 概念和术语
查看>>
ajax跨域,携带cookie
查看>>
阶段3 2.Spring_01.Spring框架简介_03.spring概述
查看>>
阶段3 2.Spring_02.程序间耦合_1 编写jdbc的工程代码用于分析程序的耦合
查看>>
阶段3 2.Spring_01.Spring框架简介_04.spring发展历程
查看>>