Description

给定有n个整数(可能为负整数)组成的序列a1,a2,...,an,求该序列连续的子段和的最大值。 如果该子段的所有元素和是负整数时定义其最大子段和为0。

Input

第一行有一个正整数n(n<1000),后面跟n个整数,绝对值都小于10000。直到文件结束。

Output

输出它的最大子段和。

Sample Input

6 -2 11 -4 13 -5 -2

Sample Output

20

参考: https://blog.csdn.net/niteip/article/details/7444973#

  1. 穷举法 时间复杂度:$O(n^3)$

    /*O(n^3)*/
    #include <stdio.h>
    #include <stdlib.h> int main()
    {
    int n;
    int num[1001];
    int i, j, k;
    int sum, max;
    while (~scanf("%d", &n))
    {
    for (i = 0; i < n; i++)
    scanf("%d", &num[i]);
    max = 0;
    for (i = 0; i < n; i++)
    {
    for (j = i; j < n; j++)
    {
    sum = 0;
    for (k = i; k <= j; k++)
    sum += num[k];
    if (sum > max)
    max = sum;
    }
    }
    printf("%d\n", max);
    }
    return 0;
    }
  2. 穷举法

    时间复杂度:$O(n^2)$

    /*O(n^2)*/
    #include <stdio.h>
    #include <stdlib.h> int main()
    {
    int n;
    int num[1001];
    int i, j, k;
    int sum, max;
    while (~scanf("%d", &n))
    {
    for (i = 0; i < n; i++)
    scanf("%d", &num[i]);
    max = 0;
    for (i = 0; i < n; i++)
    {
    sum = 0;
    for (j = i; j < n; j++)
    {
    sum += num[j];
    if (sum > max)
    max = sum;
    }
    }
    printf("%d\n", max);
    }
    return 0;
    }
  3. 分治法

    时间复杂度:$O(nlog_2n)$

    /*O(nlogn)分治法*/
    #include <iostream>
    #include <cstdio>
    #include <cstdlib> int maxSubSegSum(int num[], int left, int right)
    {
    int mid = (left + right) / 2; if (left == right)
    return num[left] > 0 ? num[left] : 0; int leftMaxSum = maxSubSegSum(num, left, mid);
    int rightMaxSum = maxSubSegSum(num, mid + 1, right); int sum = 0;
    int leftSum = 0;
    for (int i = mid; i >= left; i--)
    {
    sum += num[i];
    if (sum > leftSum)
    leftSum = sum;
    } sum = 0;
    int rightSum = 0;
    for (int i = mid + 1; i <= right; i++)
    {
    sum += num[i];
    if (sum > rightSum)
    rightSum = sum;
    } int retSum = leftSum + rightSum;
    if (retSum < leftMaxSum)
    retSum = leftMaxSum;
    if (retSum < rightMaxSum)
    retSum = rightMaxSum;
    return retSum;
    } int main()
    {
    int n;
    int num[1001]; while (~scanf("%d", &n))
    {
    for (int i = 0; i < n; i++)
    scanf("%d", &num[i]);
    printf("%d\n", maxSubSegSum(num, 0, n - 1));
    }
    return 0;
    }
  4. 动态规划

    时间复杂度:$O(n)$

    /*O(n) 动态规划*/
    #include <stdio.h>
    #include <stdlib.h>
    #include <memory.h> int main()
    {
    int n;
    int num[1001];
    int f[1001 + 1];
    int i;
    int max;
    while (~scanf("%d", &n))
    {
    for (i = 1; i <= n; i++)
    scanf("%d", &num[i]);
    max = 0;
    memset(f, 0, sizeof(f));
    for (i = 1; i <= n; i++)
    {
    if (f[i - 1] > 0)
    f[i] = f[i - 1] + num[i];
    else
    f[i] = num[i];
    if (f[i] > max)
    max = f[i];
    }
    printf("%d\n", max);
    }
    return 0;
    }

    或者

    /*O(n) 动态规划*/
    #include <stdio.h>
    #include <stdlib.h>
    #include <memory.h> int main()
    {
    int n;
    int num[1001];
    int b;
    int i;
    int max;
    while (~scanf("%d", &n))
    {
    for (i = 1; i <= n; i++)
    scanf("%d", &num[i]);
    max = 0;
    b = 0;
    for (i = 1; i <= n; i++)
    {
    b = b > 0 ? b + num[i] : num[i];
    max = b > max ? b : max;
    }
    printf("%d\n", max);
    }
    return 0;
    }

最大子段和问题(C/C++)的更多相关文章

  1. 最大子段和(c++)

    // 最大子段和.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> using namesp ...

  2. 51Node 1065----最小正子段和

    51Node  1065----最小正子段和 N个整数组成的序列a[1],a[2],a[3],…,a[n],从中选出一个子序列(a[i],a[i+1],…a[j]),使这个子序列的和>0,并且这 ...

  3. 最大M子段和 V2

    51nod1053 这题还是我们熟悉的M子段和,只不过N,M<=50000. 这题似乎是一个堆+链表的题目啊 开始考虑把所有正数负数锁在一起. 比如: 1 2 3 -1 –2 -3 666 缩成 ...

  4. 51nod 循环数组最大子段和

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1050 对于普通的数组,只要求一次最大子段和即可.但是这题是可以循环的,所 ...

  5. [日常训练]最大M子段和

    Description 在长度为的序列中选出段互不相交的子段,求最大字段和. Input 第一行两个整数. 第二行个整数. Output 一行一个整数表示最大值. Sample Input 5 2 1 ...

  6. 51nod1049(计算最大子段和)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1049 题意:又是仲文题诶- 思路:暴力会超时,又好像没什么专门 ...

  7. XCOJ 1103 (LCA+树链最大子段和)

    题目链接: http://xcacm.hfut.edu.cn/problem.php?id=1103 题目大意:链更新.链查询,求树链的最大子段和.(子段可以为空) 解题思路: 将所有Query离线存 ...

  8. 洛谷P1121 环状最大两段子段和

    题目描述 给出一段环状序列,即认为A[1]和A[N]是相邻的,选出其中连续不重叠且非空的两段使得这两段和最大. 输入输出格式 输入格式: 输入文件maxsum2.in的第一行是一个正整数N,表示了序列 ...

  9. [51NOD1959]循环数组最大子段和(dp,思路)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1050 这道题的最大子段和有两种可能,一种是常规的子段和,另一种 ...

  10. 转载:最大子段和问题(Maximum Interval Sum)

    一.问题描述         给定长度为n的整数序列,a[1...n], 求[1,n]某个子区间[i , j]使得a[i]+…+a[j]和最大.或者求出最大的这个和.       例如(-2,11,- ...

随机推荐

  1. Linux标准重定向-输入-输出-错误-多重

    一切皆文件,都是文件的操作 三种I/O设备 标准的输入输出 程序:指令+数据 读入数据:Input 输出数据:Output 系统中打开一个文件系统自动分配文件描述符,除了0,1,2是固定的,其他的都是 ...

  2. Apache Hudi助力nClouds加速数据交付

    1. 概述 在nClouds上,当客户的业务决策取决于对近实时数据的访问时,客户通常会向我们寻求有关数据和分析平台的解决方案.但随着每天创建和收集的数据量都在增加,这使得使用传统技术进行数据分析成为一 ...

  3. springboot入门系列(二):SpringBoot整合Swagger

    上一篇<简单搭建SpringBoot项目>讲了简单的搭建SpringBoot 项目,而 SpringBoot 和 Swagger-ui 搭配在持续交付的前后端开发中意义重大,Swagger ...

  4. Kerberos与票据的爱情故事

    0x01.Kerberos认证原理 Kerberos是一种认证机制.目的是通过密钥系统为客户端/服务器应用程序提供强大的可信任的第三方认证服务: 保护服务器防止错误的用户使用,同时保护它的用户使用正确 ...

  5. Redis---00概述

    一.什么是Redis? 1.概念: 是一个由Salvatore Sanfilippo写的key-value存储系统.是一个典型的NoSQL数据库, 2.特点: ①:数据是存储在内存中的 ②:是一个ke ...

  6. Luogu P5087 数学

    题意 给定一个长度为 \(n\) 的序列 \(a_i\),求出在这个序列中所有选出 \(k\) 个元素方案中元素的乘积之和. \(\texttt{Data Range:}1\leq n\leq 10^ ...

  7. Mybatis的dao层实现 接口代理方式实现规范+plugins-PageHelper

    Mybatis的dao层实现 接口代理方式实现规范 Mapper接口实现时的相关规范: Mapper接口开发只需要程序员编写Mapper接口而不用具体实现其代码(相当于我们写的Imp实现类) Mapp ...

  8. 面经手册 · 第16篇《码农会锁,ReentrantLock之公平锁讲解和实现》

    作者:小傅哥 博客:https://bugstack.cn 专题:面经手册 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 Java学多少才能找到工作? 最近经常有小伙伴问我,以为我的经验来看 ...

  9. MySQL主主数据同步

    环境 操作系统版本:CentOS 6.5 64位MySQL版本:mysql5.6节点1IP:192.168.0.235 主机名:taojiang1-mysql-01节点2IP:192.168.0.23 ...

  10. SSM使用Ueditor

    富文本编辑器(UEditor) 1. 下载UEditor富文本编辑器 建议下载 utf8-jsp 版本的,结构目录如下: 下载地址:链接:https://pan.baidu.com/s/1Nq0oJB ...