**原题链接**
##题目描述
  给出一段序列,选出其中连续且非空的一段使得这段和最大。
    **解法**:
      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 最大子序和的更多相关文章

  1. 最大子段和(洛谷P1115,动态规划递推)

    洛谷题目链接 题目赋值出来格式有问题,所以我就只放题目链接了 下面为ac代码 #include<bits/stdc++.h> #define ll long long using name ...

  2. 洛谷P1115 最大字段和【线性dp】

    题目:https://www.luogu.org/problemnew/show/P1115 题意: 求给定数组的最大区间和. 思路: $dp[i][0]$表示以1~i的数组,不选i的最大字段和.$d ...

  3. 【刷题】洛谷 P1115 最大子段和

    题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度. 第2行包含N个绝对值不大于10000 ...

  4. [DP]洛谷P1115最大子段和

    题目来源 https://www.luogu.org/problemnew/show/P1115 题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 第一行是一 ...

  5. 洛谷 P1115 最大子段和

    P1115 最大子段和 题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度. 第2行包含N ...

  6. 洛谷 - P1115 - 最大子段和 - 简单dp

    https://www.luogu.org/problemnew/show/P1115 简单到不想说……dp[i]表示以i为结尾的最大连续和的值. 那么答案肯定就是最大值了.求一次max就可以了. 仔 ...

  7. AC日记——最大子段和 洛谷 P1115

    题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度. 第2行包含N个绝对值不大于10000 ...

  8. 洛谷p1115 最大子段和

    题目链接: 最大子段和 题目分析: 动态规划O(n)求解,设f[i]表示以i为终点的最大子段和 分两种情况: 若f[i-1]>0,则显然f[i]=f[i-1]+a[i](a[i]必须包含在内) ...

  9. 洛谷P1115 最大子段和【dp】

    题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 第一行是一个正整数NN,表示了序列的长度. 第二行包含NN个绝对值不大于1000010000的整数A_iAi ...

随机推荐

  1. Maven 私服你应该不陌生吧,可你会用 Artifactory 搭建吗?

    JFrog Artifactory 是一个 Artifacts 仓库管理平台,它支持所有的主流打包格式.构建工具和持续集成(CI)服务器.它将所有二进制内容保存在一个单一位置并提供一个接口,这使得用户 ...

  2. python3.x 基础三:文件IO

    打开文件的两种方式 1.直接打开文件并赋值给变量,打开后得到操作句柄,但不会自动关闭 file = open('文件名‘,'打开模式',’编码‘) fd = open('../config/file1 ...

  3. 使用包时,报 xxx.default is not a function

     最近做了一个导出功能,代码如下 import request from 'request-promise-native'; export default class Form { // 导出 @po ...

  4. iterm 分屏切换快捷键与配色设置

    (1)快捷键设置 ⌘ + d: 垂直分屏, ⌘ + shift + d: 水平分屏. ⌘ + ]和⌘ + [在最近使用的分屏直接切换. ⌘ + opt + 方向键切换到指定位置的分屏. ⌘ + 数字: ...

  5. 王艳 201771010127《面向对象程序设计(java)》第十四周学习总结

    实验十四  Swing图形界面组件 一理论部分 1.Layout Manager(布局管理器):布局管理器是一组类,实现 java.awt.LayoutManager 接口,决定容器中组件的位置和大小 ...

  6. 本地项目链接github项目库

    本地有个用了好久用来测试功能的项目,今天用来测试链接github项目库,做一下记录   目标:把本地的项目和github上的项目连接起来 工具:sourceTree   sourceTree提供了gi ...

  7. LightOJ1030 Discovering Gold

    题目链接:https://vjudge.net/problem/LightOJ-1030 知识点: 概率与期望 解题思路: 设某一个点 \(i\) 能到达的点的个数为 \(x\),其上有金 \(g\) ...

  8. shiro的使用详解~

    在家无聊复习一下shiro 打开了之前的项目,由于lombok插件安装不了,不知道idea抽什么风所以get,set方法报错了,将就一下 只看shiro的使用,配置在shiro分类中有 登录方法 pa ...

  9. 关于 npm 包管理器最常用的内容都在这儿了

    Nodejs的诞生,给前端开发世界带来了翻天覆地的变化. 前端工程化,各种工具,以及向后端的能力扩展. 车子离不开轮子,node(前后端)开发离不开npm这个包管理工具,在这总结下常用配套工具: np ...

  10. windows环境下Kubernetes及Docker安装(那些坑)

    k8s 和 Docker容器技术,当前非常流行的技术. 让人日狗的是,   这套技术栈对CN的donet 程序员不怎么友好.娓娓道来,1. 好多镜像都是需要梯子才能访问: 2. window程序员天生 ...