最大序列和

题目

最大序列和
给出一个整数序列S,其中有N个数,定义其中一个非空连续子序列T中所有数的和为T的“序列和”。对于S的所有非空连续子序列T,求和最大的子序列。

以上说明中:N 为正整数,N≤1000000,结果序列和在范围(-2^63,2^63-1)以内。

【输入说明】

在程序当前路径下存在文件input.data,程序从input.data中读取输入数据。

input.data为单行文本文件,存放着N个整数,数字之间用空格隔开。

【输出说明]

输出和最大的子序列,数字间以空格隔开。

【示例】

输入数据:1 -2 3 4 -10 6

输出数据:3 4

思路

  1. 应注意到一个规律:负数不能是最大序列的起点,那么问题就很好解了,和为负数的序列也不能作为起点
  2. 另外注意特殊情况:数据全是负数
  3. 时间复杂度:O(n)

代码

#include <iostream>
#include <fstream>
using namespace std;

#define N 1000000

int main(int argc, char** argv) {

    fstream file("input.data");

    bool all_m = true;//是否全是非正数
    int *num = new int[N];
    int len = 0;
    while (!file.eof()) {
        file >> num[len];
        if (num[len] > 0) all_m = false;
        len++;
    }

    if (all_m) {
        int max = num[0];
        
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值