poj----Maximum sum(poj 2479)
Maximum sum
Time Limit: 1000MS |
Memory Limit: 65536K |
|
---|---|---|
Total Submissions: 30704 |
Accepted: 9408 |
Description
Given a set of n integers: A={a1, a2,..., an}, we define a function d(A) as below: Your task is to calculate d(A).
Input
The input consists of T(<=30) test cases. The number of test cases (T) is given in the first line of the input. Each test case contains two lines. The first line is an integer n(2<=n<=50000). The second line contains n integers: a1, a2, ..., an. (|ai| <= 10000).There is an empty line after each case.
Output
Print exactly one line for each test case. The line should contain the integer d(A).
Sample Input
1
10
1 -1 2 2 3 -3 4 -4 5 -5
Sample Output
13
Hint
In the sample, we choose {2,2,3,-3,4} and {5}, then we can get the answer. Huge input,scanf is recommended.
Source
POJ Contest,Author:Mathematica@ZSU
题意:
给一个数列,求出数列中不相交的两个字段和,要求和最大。
思路:
对每一个i来说,求出【0~i-1】的最大子段和以及【i~n-1】的最大子段和,再加起来求最大的一个就行了。[0~i-1]的最大子段和从左向右扫描,【i~n-1】从右想左扫描
即可,时间复杂度O(n).
代码:
1 #include<iostream>
2 #include<cstdio>
3 #define maxn 50001
4 #include<algorithm>
5 using namespace std;
6 int a[maxn];
7 int left[maxn];
8 int right[maxn];
9 int max(int a,int b)
10 {
11 return a>b?a:b;
12 }
13 int main()
14 {
15 int t,i;
16 scanf("%d",&t);
17 while(t--)
18 {
19 int n;
20 scanf("%d",&n);
21 for(i=0;i<n;i++)
22 scanf("%d",&a[i]);
23 //此时::left【i】为包涵i最大字段和
24 ::left[0]=a[0];
25 for( i=1; i<n;i++)
26 if(::left[i-1]<0)
27 ::left[i]=a[i];
28 else
29 ::left[i]=::left[i-1]+a[i];
30 //此时left[i]为i左边最大字段和
31 for(i=1; i<n;i++)
32 ::left[i]=max(::left[i],::left[i-1]);
33 ::right[n-1]=a[n-1];
34 for(i=n-2;i>=0;i--)
35 {
36 if(::right[i+1]<0)
37 ::right[i]=a[i];
38 else
39 ::right[i]=::right[i+1]+a[i];
40 }
41 for(i=n-2;i>=0;i--)
42 ::right[i]=max(::right[i+1],::right[i]);
43 int res=-100000000;
44 for(i=1;i<n;i++)
45 {
46 res=max(res,::left[i-1]+::right[i]);
47 }
48 printf("%dn",res);
49 }
50 return 0;
51 }
- 使用JavaScript访问XML数据
- 详解Android UI线程卡顿收集
- 浅谈差分约束问题
- JVM活学活用——类加载机制
- WebAssembly详解及其使用案例
- 30分钟精通快应用
- BZOJ2440: [中山市选2011]完全平方数(莫比乌斯+容斥原理)
- Dapper扩展之~~~Dapper.Contrib
- JVM活学活用——GC算法 垃圾收集器
- BZOJ1101: [POI2007]Zap(莫比乌斯反演)
- freeRTOS事件组学习
- 洛谷P2522 [HAOI2011]Problem b(莫比乌斯反演)
- JVM活学活用——优化springboot
- .Net中的AOP读书笔记系列之AOP介绍
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- TypeScript 4.1 新特性:字符串模板类型,Vuex 终于有救了?
- 使用 Node.js 定制你的技术雷达:上篇
- 使用 Node.js 定制你的技术雷达:中篇
- 大点干!早点散----------Redis从入门到精通!!!
- Python入门摘要
- 这些 ECMAScript 模块知识,都是我需要知道的
- 微信小程序【事件绑定】入门一篇就搞定
- 一个后端狗的 Vue 笔记【入门级】
- 这才是现代C++单例模式简单又安全的实现
- Linux 学习笔记(1) 查看文件内容
- Python从入门到熟练(3):第一个程序
- 数学系的概率论和我们的不太一样。。。
- 如何实现一个优雅的Python的Json序列化库
- 还在从零开始搭建项目?手撸了款快速开发脚手架!
- Node.js 中的 require 是如何工作的?