N个整数组成的序列a[1],a[2],a[3],…,a[n],求该序列如a[i]+a[i+1]+…+a[j]的连续子段和的最大值。当所给的整数均为负数时和为0。

例如:-2,11,-4,13,-5,-2,和最大的子段为:11,-4,13。和为20。
Input
第1行:整数序列的长度N(2 <= N <= 50000)
第2 - N + 1行:N个整数(-10^9 <= A[i] <= 10^9)
Output
输出最大子段和。
Input示例
6
-2
11
-4
13
-5
-2
Output示例
20
给一组数据:http://paste.ubuntu.com/25117542/
方法一:分冶法,递归求解,每次将所求区间折半,一个从中间往左便利,一个从中间向右便利(保证和值存在于连续的区间),即一个左值,一个右值,两者相加求和值,三者比较求最大,不断递归,求最大区间和
suml(1,n)=sum(1,n/2),sumr(1,n)=sum(n/2+1,n);sum=suml+sumr;sum=max(sum,max(suml,sumr));
[1]、a[1:n]的最大子段和与a[1:n/2]的最大子段和相同; 
[2]、a[1:n]的最大子段和与a[n/2+1:n]的最大子段和相同;
[3]、a[1:n]的最大字段和为,且1<=i<=n/2,n/2+1<=j<=n。

可用递归方法求得情形[1],[2]。对于情形[3],可以看出a[n/2]与a[n/2+1]在最优子序列中。因此可以在a[1:n/2]中计算出,并在a[n/2+1:n]中计算出。则s1+s2即为出现情形[3]时的最优值。

代码如下:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cmath>
#include <map>
#include <set>
#include <vector>
#include <algorithm>
using namespace std;
#define lowbit(x) (x&(-x))
#define max(x,y) (x>y?x:y)
#define min(x,y) (x<y?x:y)
#define MAX 100000000000000000
#define MOD 1000000007
#define PI 3.141592653589793238462
#define INF 0x3f3f3f3f3f
#define mem(a) (memset(a,0,sizeof(a)))
typedef long long ll;
ll a[],n;
ll TDQ(ll *a,ll left,ll right)
{
if(right==left)
{
return a[left]>?a[left]:;
}
ll mid=(left+right)>>;
ll leftsum=TDQ(a,left,mid);
ll rightsum=TDQ(a,mid+,right);
ll suml=a[mid],sumr=a[mid+],sl=,sr=;
ll sum;
for(ll i=mid;i>=left;i--)
{
sl+=a[i];
suml=max(suml,sl);
}
for(ll i=mid+;i<=right;i++)
{
sr+=a[i];
sumr=max(sumr,sr);
}
sum=suml+sumr;
sum=max(sum,max(leftsum,rightsum));
return sum;
}
int main()
{
scanf("%lld",&n);
for(int i=;i<=n;i++)
scanf("%lld",&a[i]);
ll sum=TDQ(a,,n);
printf("%lld\n",sum);
return ;
}

方法二:动态规划

区间和b大于0时就往下加,否则归零。

//最大字段求和动态规划
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cmath>
#include <map>
#include <set>
#include <vector>
#include <algorithm>
using namespace std;
#define lowbit(x) (x&(-x))
#define max(x,y) (x>y?x:y)
#define min(x,y) (x<y?x:y)
#define MAX 100000000000000000
#define MOD 1000000007
#define PI 3.141592653589793238462
#define INF 0x3f3f3f3f3f
#define mem(a) (memset(a,0,sizeof(a)))
typedef long long ll;
ll dp[],a[],n;
int main()
{
int ans=;
scanf("%I64d",&n);
for(int i=;i<=n;i++)
{
scanf("%I64d",&a[i]);
if(a[i]<) ans++;
}
ll sum=,sumson=;
for(int i=;i<=n;i++)
{
if(sumson>) sumson+=a[i];
else sumson=a[i];
sum=max(sum,sumson);
}
printf("%I64d\n",sum);
return ;
}

最新文章

  1. Hadoop2.2.0 hive0.12 hbase0.94 配置问题记录
  2. 二十六:Struts2 和 spring整合
  3. Fragment使用问题
  4. 转:So Easy!让开发人员更轻松的工具和资源
  5. MVC几个系统常用的Filter过滤器
  6. 前端jquery validate表单验证框架的使用
  7. Docker for windows10 配置镜像加速
  8. Servlet - Listener、Filter、Decorator
  9. OSPF 基础实验
  10. UEditor单图上传跨域问题解决方案
  11. Python数据类型的内置函数之list(列表)
  12. tf.assign,tf.assign_add,tf.assign_sub
  13. 【ASP.NET 插件】分享一个可视化HTML编辑器 CKEditor.NET
  14. android apk 反编译过程
  15. IIS日志自动清理
  16. 生命周期方法调用,以及在onStop()方法中处理草稿信息
  17. 第三百四十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—cookie禁用、自动限速、自定义spider的settings,对抗反爬机制
  18. 动画-缩放,旋转 CGAffineTransform
  19. VS Code折腾记 - (3) 多图解VSCode基础功能
  20. 在命令行上 Ubuntu 下使用 mutt 和 msmtp 发送 Gmail 邮件

热门文章

  1. 使得nginx支持pathinfo访问模式
  2. kubernetes学习与实践篇(二) kubernetes1.5 的安装和集群环境部署
  3. lhgDialog使用--loading提示(不自动关闭)
  4. BZOJ4472
  5. 【转载】Perl中字符串编码的处理
  6. 今日SGU 5.30
  7. [NOIP1999]进制位(搜索)
  8. 从串口设置、读取、并分析um220模块的数据
  9. openGl超级宝典学习笔记 (2) 7个主要的几何图元
  10. hdu 1695 GCD (欧拉函数、容斥原理)