最大子段和 模板题 51Nod 1049
N个整数组成的序列a[1],a[2],a[3],…,a[n],求该序列如a[i]+a[i+1]+…+a[j]的连续子段和的最大值。当所给的整数均为负数时和为0。
第1行:整数序列的长度N(2 <= N <= 50000)
第2 - N + 1行:N个整数(-10^9 <= A[i] <= 10^9)
输出最大子段和。
6
-2
11
-4
13
-5
-2
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 ;
}
最大子段和 模板题 51Nod 1049的更多相关文章
- 51Nod 1049最大子段和  | 模板
		
Input示例 6 -2 11 -4 13 -5 -2 Output示例 20 1.最大子段和模板 #include "bits/stdc++.h" using namespace ...
 - 51Nod 博弈模板题
		
连刷3道博弈模板题,算是稍微学习了以下三个经典博弈了.推荐一个博客. 第一道模板:Bash博弈——同余理论 1066 Bash游戏 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度 ...
 - 51nod 1028 大数乘法 V2 【FFT模板题】
		
题目链接 模板题.. #include<bits/stdc++.h> using namespace std; typedef int LL; typedef double db; nam ...
 - 51nod 1086背包问题V2 (完全背包模板题)
		
1086 背包问题 V2 1 秒 131,072 KB 20 分 3 级题 题目描述 有N种物品,每种物品的数量为C1,C2......Cn.从中任选若干件放在容量为W的背包里,每种物品的体积为W1, ...
 - [AHOI 2009] 维护序列(线段树模板题)
		
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...
 - HDU 2222 AC自动机模板题
		
题目: http://acm.hdu.edu.cn/showproblem.php?pid=2222 AC自动机模板题 我现在对AC自动机的理解还一般,就贴一下我参考学习的两篇博客的链接: http: ...
 - POJ2774 & 后缀数组模板题
		
题意: 求两个字符串的LCP SOL: 模板题.连一起搞一搞就好了...主要是记录一下做(sha)题(bi)过程心(cao)得(dan)体(xin)会(qing) 后缀数组概念...还算是简单的,过程 ...
 - HDU 1251  Trie树模板题
		
1.HDU 1251 统计难题 Trie树模板题,或者map 2.总结:用C++过了,G++就爆内存.. 题意:查找给定前缀的单词数量. #include<iostream> #incl ...
 - HDU-3549     最大流模板题
		
1.HDU-3549 Flow Problem 2.链接:http://acm.hdu.edu.cn/showproblem.php?pid=3549 3.总结:模板题,参考了 http://ww ...
 
随机推荐
- jdk--rpm.bin文件安装,  zip解压与创建
			
3,执行命令赋予安装文件777权限: # cd /usr/java(mkdir java –此目录需要创建) ①jdk-1_5_0_16-linux-i586-rpm.bin文件安装 # chmod ...
 - Mojo For Chromium Developers1
			
Mojo For Chromium Developers Overview This document contains the minimum amount of information neede ...
 - 监控mysqld服务
			
#!/bin/bash #监控mysqld服务 #telnet 192.168.122.171 3306 | grep Connected | wc -l #远程检查 #num=`netstat -n ...
 - Object-C,遍历目录
			
最近武汉连续下雨很多天,降温了2次,温度一下子由28度到14度,再到8度,手太冷了. 加上最近发生了一些比较棘手的家庭琐事,最近没心情继续学习Object-C. 后来,我想明白了,心情不好的时候,还是 ...
 - HDU 4928 Series 2
			
有了题解以后这题就成了一个模拟题.不过写了好久才把它写对…… Sad #include <iostream> #include <cstdio> #include <cs ...
 - Win10平台下通过VMware虚拟机安装Win7、Ubuntu、Mac
			
1.安装VMware14.1.1 下载地址:https://download.csdn.net/download/jasonczy/10611423 产品秘钥: CG54H-D8D0H-H8DHY-C ...
 - iOS学习9_事件分发&响应链
			
iOS的三种事件:触摸事件/运动事件/远程控制事件 typedef enum { UIEventTypeTouches, UIEventTypeMotion, UIEventTypeRemoteCon ...
 - Linux能ping通IP,ping不通域名
			
今天碰到个问题, 能ping通IP地址, ping不通域名, 一直以为是 DNS解析服务器的问题, 找了半天. 问题不在这里. [root@www postfix]# cat /etc/resolv. ...
 - 正则表达式 Tricks
			
*:0 或 多个 ?:任意一个 [list]:a[xyz]b,a 与 b 之间必须也只能有一个字符,但只能是 x/y/z,也即:axb, ayb, azb [!list]:匹配除 list 中的任意单 ...
 - codeforces Gym100589H Count Subarrays 树状数组/线段树+离散化
			
题意:给你一个数组,问你有多少子数组中的逆元数不小于K个,N<105 还在研究中
 
			
		
,且1<=i<=n/2,n/2+1<=j<=n。