当前位置:网站首页>HDU - 1024 Max Sum Plus Plus(DP)
HDU - 1024 Max Sum Plus Plus(DP)
2022-07-01 05:23:00 【WA_自动机】
HDU - 1024 Max Sum Plus Plus(DP)
Problem Description
Now I think you have got an AC in Ignatius.L’s “Max Sum” problem. To be a brave ACMer, we always challenge ourselves to more difficult problems. Now you are faced with a more difficult problem.
Given a consecutive number sequence S1, S2, S3, S4 … Sx, … Sn (1 ≤ x ≤ n ≤ 1,000,000, -32768 ≤ Sx ≤ 32767). We define a function sum(i, j) = Si + … + Sj (1 ≤ i ≤ j ≤ n).
Now given an integer m (m > 0), your task is to find m pairs of i and j which make sum(i1, j1) + sum(i2, j2) + sum(i3, j3) + … + sum(im, jm) maximal (ix ≤ iy ≤ jx or ix ≤ jy ≤ jx is not allowed).
But I`m lazy, I don’t want to write a special-judge module, so you don’t have to output m pairs of i and j, just output the maximal summation of sum(ix, jx)(1 ≤ x ≤ m) instead.
Input
Each test case will begin with two integers m and n, followed by n integers S1, S2, S3 … Sn.
Process to the end of file.
Output
Output the maximal summation described above in one line.
Sample Input
1 3 1 2 3
2 6 -1 4 -2 3 -2 3
Sample Output
6
8
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N = 1000010;
int a[N],f[N];
int main()
{
int n,m;
while(scanf("%d%d",&m,&n)!=EOF)
{
memset(f,0,sizeof f);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
for(int i=1;i<=m;i++)
{
int sum=0;
for(int j=1;j<=i;j++)
sum+=a[j];
f[n]=sum;
for(int j=i+1;j<=n;j++)
{
sum=max(sum,f[j-1])+a[j];
f[j-1]=f[n];
f[n]=max(f[j-1],sum);
}
}
printf("%d\n",f[n]);
}
return 0;
}
边栏推荐
- El cascade echo failed; El cascader does not echo
- TypeORM 框架
- C WPF uses dockpanel to realize screenshot box
- Thread safety issues
- Redis数据库的部署及常用命令
- Principle, technology and implementation scheme of data consistency in distributed database
- 如何创建一个根据进度改变颜色的进度条
- What can the points mall Games bring to businesses? How to build a points mall?
- Redis database deployment and common commands
- 液压滑环的特点讲解
猜你喜欢
![[NLP Li Hongyi] notes](/img/8e/a51ca5eee638facd54270fb28d2fce.jpg)
[NLP Li Hongyi] notes

Leetcode1497- check whether array pairs can be divided by K - array - hash table - count

And search: the suspects (find the number of people related to the nth person)

Thread process foundation of JUC

C WPF uses dockpanel to realize screenshot box

0xc000007b the application cannot start the solution normally (the pro test is valid)
![Is there any good website or software for learning programming? [introduction to programming]?](/img/ae/68a5880f313c307880ac80bd200530.jpg)
Is there any good website or software for learning programming? [introduction to programming]?

Implementation of distributed lock

Copier le matériel de conseils de bébé ne peut pas être vide, comment résoudre?

如何创建一个根据进度改变颜色的进度条
随机推荐
Global and Chinese markets of InGaAs APD arrays 2022-2028: Research Report on technology, participants, trends, market size and share
Go learning notes (5) basic types and declarations (4)
Rust hello-word
C# wpf 使用DockPanel实现截屏框
Use and principle of wait notify
3D建模與處理軟件簡介 劉利剛 中國科技大學
Single page application
Summary of spanner's paper
Understand several related problems in JVM - JVM memory layout, class loading mechanism, garbage collection
Precautions for use of conductive slip ring
LeetCode316-去除重复字母-栈-贪心-字符串
Distributed transactions - Solutions
C WPF uses dockpanel to realize screenshot box
Global and Chinese market of search engine optimization (SEO) software 2022-2028: Research Report on technology, participants, trends, market size and share
JS random verification code
Unit testing with mongodb
Unity项目心得总结
导电滑环短路的原因以及应对措施
LeetCode1497-检查数组对是否可以被 k 整除-数组-哈希表-计数
LeetCode522-最长特殊序列II-哈希表-字符串-双指针