洛谷 P1115 最大子序和
**原题链接**
##题目描述
给出一段序列,选出其中连续且非空的一段使得这段和最大。
**解法**:
1、暴力枚举 时间:O(n^3)
2、简单优化 时间:O(n^2)
3、分治 时间:O(nlogn)
4、DP 时间:O(n)
分析与代码
解法1:暴力枚举 时间:O(n^3)
由题意很容易想到通过枚举子串首尾两端的位置
确定找出不同的子串,并把确定子串中的数逐一
相加求和,从中取最大值暴力解决。
代码
#include<iostream>
using namespace std;
const int N=100010;
int a[N];
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++)cin>>a[i];
int MaxSum=-(1<<30),ThisSum;
for(int i=0;i<n;i++){
for(int j=i;j<n;j++){
ThisSum=0;
for(int k=i;k<=j;k++)ThisSum+=a[k];
MaxSum=max(MaxSum,ThisSum);
}
}
cout<<MaxSum<<endl;
return 0;
}
解法2:简单优化 时间:O(n^2)
简单思考可发现,解法1中做了很多次重复计算,
如下图:

当子序起始位置不变,末端移动的时候,ThisSum只会依次加上新的一个数。所以,
只需枚举子串首尾两端的位置,每次子序末端移动的时候,
新子序和等于ThisSum=ThisSum+a[j]即可。
代码
#include<iostream>
using namespace std;
const int N=1000010;
int a[N];
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++)cin>>a[i];
int MaxSum=-(1<<30),ThisSum=0;
for(int i=0;i<n;i++){
ThisSum=0;
for(int j=i;j<n;j++){
ThisSum+=a[j];
MaxSum=max(MaxSum,ThisSum);
}
}
return 0;
}
解法3:分治 时间:O(nlogn)
(未完待续......)
解法4:DP 时间:O(n)
其实,再深入思考,可以发现当枚举计算ThisSum<0
的时候,再去子序末端移动过后遇到的无论是正数
还是负数,当它加上ThisSum时都将小于它本身。所
以ThisSum<0时,可以看成0从头处理。但还有一种特
殊情况——原序列全是负数!!!
由此可以得出以下状态转移方程:
MaxSum=max( MaxSum , max(ThisSum+a[i],a[i])
整个过程只需扫一遍数组即可,所以T(n)=O(n)。
代码
#include<iostream>
using namespace std;
const int N=1000010;
int a[N];
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++)cin>>a[i];
int MaxSum=-(1<<30),ThisSum=0;
for(int i=0;i<n;i++){
ThisSum+=a[i];
MaxSum=max(MaxSum,ThisSum);
if(ThisSum<0)ThisSum=0;
}
cout<<MaxSum<<endl;
return 0;
}
洛谷 P1115 最大子序和的更多相关文章
- 最大子段和(洛谷P1115,动态规划递推)
洛谷题目链接 题目赋值出来格式有问题,所以我就只放题目链接了 下面为ac代码 #include<bits/stdc++.h> #define ll long long using name ...
- 洛谷P1115 最大字段和【线性dp】
题目:https://www.luogu.org/problemnew/show/P1115 题意: 求给定数组的最大区间和. 思路: $dp[i][0]$表示以1~i的数组,不选i的最大字段和.$d ...
- 【刷题】洛谷 P1115 最大子段和
题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度. 第2行包含N个绝对值不大于10000 ...
- [DP]洛谷P1115最大子段和
题目来源 https://www.luogu.org/problemnew/show/P1115 题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 第一行是一 ...
- 洛谷 P1115 最大子段和
P1115 最大子段和 题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度. 第2行包含N ...
- 洛谷 - P1115 - 最大子段和 - 简单dp
https://www.luogu.org/problemnew/show/P1115 简单到不想说……dp[i]表示以i为结尾的最大连续和的值. 那么答案肯定就是最大值了.求一次max就可以了. 仔 ...
- AC日记——最大子段和 洛谷 P1115
题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度. 第2行包含N个绝对值不大于10000 ...
- 洛谷p1115 最大子段和
题目链接: 最大子段和 题目分析: 动态规划O(n)求解,设f[i]表示以i为终点的最大子段和 分两种情况: 若f[i-1]>0,则显然f[i]=f[i-1]+a[i](a[i]必须包含在内) ...
- 洛谷P1115 最大子段和【dp】
题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 第一行是一个正整数NN,表示了序列的长度. 第二行包含NN个绝对值不大于1000010000的整数A_iAi ...
随机推荐
- mac下charles使用
设置charles 电脑上一次性的工作 1 下载下面两个文件(这里版本自己定) a charles-proxy-4.1.4.dmg b charles4.1.4的副本.jar 2 进行charles ...
- pssh远程执行命令的利器
pssh -h hosts.txt -l irb2 -o /tmp/foo uptime -l 后面加用户,很好理解,执行uptime,然后把结果写入/tmp/foo目录. pscp -h hosts ...
- 《C程序设计语言》 练习3-5
问题描述 练习 3-5 编写函数 itob(n, s, b),将整数n转换为以b为底的数,并将转换结果以字符的形式保存到字符串s中.例如,itob(n, s, 16)把整数n格式化成十六进制整数保存在 ...
- js 获取table tr td内的select 和input text
$("#TableList tr").each(function () { //for (var i = 1; i <= AM_index; i ...
- LeetCode上的SQL练习
184. 部门工资最高的员工 SELECT D. NAME Department, E. NAME Employee, E.Salary FROM -- 内连接两张查询表 Employee E INN ...
- 去重函数unique,sort,erase的应用
std::unique 一.总述 unique函数属于STL中比较常用函数,它的功能是元素去重.即"删除"序列中所有相邻的重复元素(只保留一个).此处的删除,并不 是真的删除,而是 ...
- 加密通信软件Signal 2.92版本编译安装折腾手记(Ubuntu 18.04)
加密通信软件Signal 2.92版本编译安装折腾手记(Ubuntu 18.04) 前言 加密通信软件Signal是开源的,安全性很高,号称斯诺登也推荐大家使用.既然这么好,那必然会有不少人去尝试复制 ...
- 2020由浅入深最强Java面试题
1.String,StringBuffer和StringBuilder有什么区别? String是字符串常量,不可变对象,每次对String修改都等同于生成了一个新的String象,然后将指针 ...
- Java——枚举类(疯狂Java讲义6.9)
枚举类:有限而固定的类,使用enum关键字定义. 一个Java源文件中最多只能定义一个public访问权限的枚举类. 1.可实现一个或多个接口,默认集成了java.lang.Enum类(实现java. ...
- Java中的集合(十二) 实现Map接口的WeakHashMap
Java中的集合(十二) 实现Map接口的WeakHashMap 一.WeakHashMap简介 WeakHashMap和HashMap一样,WeakHashMap也是一个哈希表,存储的也是键值对(k ...