poj2479 Maximum sum
http://poj.org/problem?id=2479
题目大意:给定一组n个整数:a ={a1, a2,…,我们定义一个函数d(a)如下:

你的任务是计算d(A)。输入由T(<=30)测试用例组成。在输入的第一行中给出了测试用例(T)的数量。
每个测试用例包含两行。第一行是一个整数n(2<=n<=50000)。第二行包含n个整数:a1, a2,…,an。 ( | ai | < = 10000)。为每个测试用例打印一行。该行应该包含整数d(A)。
也就是说求最大的子段和,给定一个数组,求数组里左子段的和加上右子段的和的最大值。
算法思想:动态规划,用left[i]表示第1个数到第i个数的最大子段和,用right[i]表示第i个数到第n个数的最大值。我们要求的就是left[i]+right[i+1]的最大值。
状态转移方程:
1) left[i]=max{left[i-1]+a[i],a[i]} i=1,2,3,…;
2) right[i]=max{right[i+1]+a[i],a[i]} i=n,n-1,…;
3) max=max{left[i]+right[i+1]} i=n,n-1,…;
#include <iostream>
using namespace std;
int MaximumSum(int a[],int n)
{
int sum = , max=INT_MIN;
int *left, *right;
left = new int[n + ];
right = new int[n + ];
left[] = -;
right[n + ] = -;
for (int i = ; i < n; i++)
{
sum = sum + a[i];
if (sum > left[i-])left[i] = sum;
else left[i] = left[i-];
if (sum < )sum = ;//累加为负数时更新sum
}
sum = ;
for (int i = n; i > ; i--)
{
sum = sum + a[i];
if (sum > right[n+])right[i] = sum;
else right[i] = right[i + ];
if (sum < )sum = ;
if (right[i] + left[i - ] > max)max = right[i] + left[i - ];//在此可直接计算max
}
delete []left;
delete []right;
return max;
}
int main()
{
int t, n;
int array[];
cin >> t;
for (int i = ; i < t; i++)
{
cin >> n;
for (int j = ; j <= n; j++)
{
scanf_s("%d", &array[j]);
}
cout << MaximumSum(array, n) << endl;
} return ;
}
poj2479 Maximum sum的更多相关文章
- POJ2479 Maximum sum[DP|最大子段和]
Maximum sum Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 39599 Accepted: 12370 Des ...
- POJ2479 Maximum sum(dp)
题目链接. 分析: 用 d1[i] 表示左向右从0到i的最大连续和,d2[i] 表示从右向左, 即从n-1到i 的最大连续和. ans = max(ans, d1[i]+d2[i+1]), i=0,1 ...
- POJ-2479 Maximum sum(动态规划)
最大子序列和的加强版. 借助最大子序列和,分别正向和反向遍历一遍得到left和right数组(具体含义见代码注释) 然后再对left和right数组进行修正,保存从对应元素起向左或向右的最大连续和. ...
- ural 1146. Maximum Sum
1146. Maximum Sum Time limit: 0.5 secondMemory limit: 64 MB Given a 2-dimensional array of positive ...
- UVa 108 - Maximum Sum(最大连续子序列)
题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...
- 最大子矩阵和 URAL 1146 Maximum Sum
题目传送门 /* 最大子矩阵和:把二维降到一维,即把列压缩:然后看是否满足最大连续子序列: 好像之前做过,没印象了,看来做过的题目要经常看看:) */ #include <cstdio> ...
- URAL 1146 Maximum Sum(最大子矩阵的和 DP)
Maximum Sum 大意:给你一个n*n的矩阵,求最大的子矩阵的和是多少. 思路:最開始我想的是预处理矩阵,遍历子矩阵的端点,发现复杂度是O(n^4).就不知道该怎么办了.问了一下,是压缩矩阵,转 ...
- ural 1146. Maximum Sum(动态规划)
1146. Maximum Sum Time limit: 1.0 second Memory limit: 64 MB Given a 2-dimensional array of positive ...
- UVa 10827 - Maximum sum on a torus
题目大意:UVa 108 - Maximum Sum的加强版,求最大子矩阵和,不过矩阵是可以循环的,矩阵到结尾时可以循环到开头.开始听纠结的,想着难道要分情况讨论吗?!就去网上搜,看到可以通过补全进行 ...
随机推荐
- Stripies
/* Our chemical biologists have invented a new very useful form of life called stripies (in fact, th ...
- 前后台交互(打开前端页面,不传递任何数据,发送ajax请求)
1.打开前端,不传递任何数据 <script src="./jquery.min.js"></script> <script> $(docume ...
- filter 死循环(tomcat 启动完成 ,自动执行filter.dofilter,导致tomcat 启动超时) , tomcat 启动和 servers 启动 不同
package com.diancai.interceptor; import java.io.IOException; import javax.servlet.Filter; import jav ...
- URL编码转换函数:escape()、encodeURI()、encodeURIComponent()
函数出现时间: escape() javascript 1.0 ...
- 【JAVA】通过URLConnection/HttpURLConnection发送HTTP请求的方法(一)
Java原生的API可用于发送HTTP请求 即java.net.URL.java.net.URLConnection,JDK自带的类: 1.通过统一资源定位器(java.net.URL)获取连接器(j ...
- sqlserver实现分页的几种方式
sqlserver实现分页的几种方式 第一种:使用org.springframework.data.domain.Page来进行分页 package com.cellstrain.icell.repo ...
- 安装memcache服务
d:\tools\memcache\setup\memcached -d install
- 12) maven-compiler-plugin
The Compiler Plugin is used to compile the sources of your project. At present the default source se ...
- 10.N个整数中查找是否相加为K[深度搜索]
/*摘自书本,这种算法很绕!*/ #include <iostream> using namespace std; ,,,}; ; bool dfs(int i,int sum) { if ...
- hdu1081 To The Max 2016-09-11 10:06 29人阅读 评论(0) 收藏
To The Max Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...