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

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

题目描述

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

数组

最朴素做法:

int FindGreatestSumOfSubArray(vector
array) { int len = array.size(); int dp[400][400] = {
0}; int res = -214748; for(int i = 1; i < len;i++) { dp[i][i] = array[i-1]; if(dp[i][i] > res) res = dp[i][i]; } for(int i = 1; i <= len;i++) { for(int j = i+1; j <= len;j++) { dp[i][j] = dp[i][j-1] + array[j-1]; if(dp[i][j] > res) res = dp[i][j]; } } return res; }

动态规划想法:

int FindGreatestSumOfSubArray(vector
array) { int len = array.size(); int dp[400] = {
0}; int res = array[0]; for(int i = 1; i <= len;i++) { dp[i] = dp[i-1]+array[i-1] > array[i-1] ? dp[i-1]+array[i-1]:array[i-1]; if(res < dp[i]) res = dp[i]; } return res; }

1.dp方程:dp[i] 为以第i为结尾的数组最大值。

2.转换方程  : 我们只需要保证以第i个数为结尾的最大值,比较第i-1个值+当前值,与当前值,选取大的。

      可以通俗的理解成,前面已经是负的了,重新设一个新的起点。

转载于:https://www.cnblogs.com/Lune-Qiu/p/9126105.html

你可能感兴趣的文章
阿里技术高P访谈之“呆萌”程序员蒋晓伟为何从Facebook到阿里巴巴
查看>>
OSSIM插件开发实战(配视频)
查看>>
深入Protobuf源码-Descriptor、Message、RPC框架
查看>>
图像处理------调整亮度与饱和度
查看>>
Otter-入门篇4(单向同步实践)
查看>>
【阿里在线技术峰会】方超:阿里聚安全在互联网业务中的创新实践
查看>>
SOCKET 编程TCP/IP、UDP
查看>>
CAN总线基础知识(二)
查看>>
MySQL内核月报 2014.09-MySQL· 限制改进·GTID和升级
查看>>
Angular Input格式化
查看>>
mysql backup 脚本
查看>>
spring 和hibernate项目制作可执行的jar包
查看>>
xfs vs jfs vs reiserfs
查看>>
编译单个Java文件引入jar包
查看>>
Windows无法安装到这个磁盘。请确保在计算机的BIOS菜单中启用了磁盘控制器
查看>>
Fluent interface
查看>>
java定时器和多线程实践记录
查看>>
HashMap源码分析(jdk1.8)
查看>>
iOS加载程序视图的方式
查看>>
【技术干货】基于Jquery实现Web应用国际化
查看>>