如何求连续几个数之和的最大值

 更新时间:2013年05月28日 17:34:56   作者:  
本篇文章是对如何求连续几个数之和的最大值进行了详细的分析介绍,需要的朋友参考下
给定一组数,有正有负,求连续的几个数之和的最大值?并求出是从第几个数开始,第几个数结束?如果有多个序列可组成相同的最大值,则选取最开始的一个序列。(注:这两天看《编程之美》,发现2.14节,求数组的子数组之和的最大值,跟这个题十分相似,但是没有要求求出开始喝结束的位置,只要求求出最大值,解题思路跟下面的代码相似,但只用了两个变量,没有用数组,做到时间复杂度O(n),空间复杂度O(1))
用程序设计实现。我实现了一种方法,跟大家分享一下,如果朋友你有更好的方法来解决这个问题,希望你能回复,与大家分享一下。
另外,如果题目改成:“给定一组数,有正有负,求连续的几个数之和的最大值?并求出是从第几个数开始,第几个数结束?如果有多个序列可组成相同的最大值,则选取序列中数字最少的那个。”该怎么写程序,本人思考良久没有想到好的办法。求指点!!!!!!!
下面是我实现的C++代码:
复制代码 代码如下:

#include "stdafx.h"
#include <iostream>
using namespace std;
int GetMaxs(int arrary[],const int n)
{
 int max = 0, temp = 0;  //max最大值,temp临时变量
 int begin = 0, end = 0;
 int *maxlist= new int[n]; //maxlist[n],一个数组,跟原数组一般大
 max = maxlist[0] = arrary[0];
 begin = end = arrary[0];
 for (int i = 1; i < n; i++)
 {
  temp = maxlist[i - 1] + arrary[i];
  if (temp > arrary[i])
  {
   maxlist[i] = maxlist[i - 1] + arrary[i]; //更新最大值数组
  }
  else
  {
   maxlist[i] = arrary[i]; //更新最大值数组
  }
  if (maxlist[i] > max)
  {
   max = maxlist[i]; //用当前值更新最大值
   end = i; //设置终点索引
  }
 }
 //下面几句是寻找起始点
 int j = end, sum = 0;
 while (j < n && sum != max )
 {
  sum += arrary[j];
  j --;
 }
 begin = ++j;
 cout << "The max sum is: " << max << endl;
 cout << "The begin position is: " << ++begin << endl;
 cout << "The end position is: " << ++end << endl;
 return 0;
}
int _tmain(int argc, _TCHAR* argv[])
{
 //int a[] = {-1,-1,-1,1,1,1,-1,-1,-1,-1,1,1,-1,1,1,-1};
 int a[] = {5,8,12,-25,-15,56,-14,25,2,-10,6};
 int n = sizeof(a)/sizeof(a[0]);
 GetMaxs(a,n);
 return 0;
}

另外一道很相似的题目:有一个数组a[n],里面的数只有两种:-1和1。  i、j是两个整数,假设0 <= i < j <= n -1 ,找出a[i]到a[j]中连续数之和最大的部分(如果最大部分存在相等,则优先找最短的)。
这道题和上面的题类似,只不过本人还是想不出怎么取最短,只做到取首次取得最大值。

相关文章

  • C语言中快速排序和插入排序优化的实现

    C语言中快速排序和插入排序优化的实现

    这篇文章主要介绍了C语言中快速排序和插入排序优化的实现,包括双向划分快速排序方法的介绍,需要的朋友可以参考下
    2015-11-11
  • C语言详细讲解常用字符串处理函数

    C语言详细讲解常用字符串处理函数

    在日常编程中,对于字符串的操作中我们都很习惯的使用一些C库中自带的函数,并且关于字符串的操作函数基本都在 string.h 这个头文件中。关于C库字符串常用处理函数也是平时面试或者考试过程中非常喜欢考的,本文将带大家手动来实现这些常用函数
    2022-05-05
  • 关于c++ 智能指针及 循环引用的问题

    关于c++ 智能指针及 循环引用的问题

    下面小编就为大家带来一篇关于c++ 智能指针及 循环引用的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • C++面试八股文之如何实现strncpy函数

    C++面试八股文之如何实现strncpy函数

    strncpy函数,主要用做字符串复制,将于字符从一个位置复制到另一个位置,那么如何实现一个strncpy函数,下面小编就来和大家简单讲讲吧
    2023-07-07
  • C语言实现字母大小写转换的方法

    C语言实现字母大小写转换的方法

    这篇文章主要介绍了C语言实现字母大小写转换的方法,涉及C语言字符串的遍历与转换技巧,非常简单实用,需要的朋友可以参考下
    2015-07-07
  • C++在非面向对象方面对C语言的扩充

    C++在非面向对象方面对C语言的扩充

    C++是一种面向对象编程语言,但它也可以作为C语言的扩展语言。在C++中,我们可以使用非面向对象方面的特性来扩展C语言。在本文中,我们将讨论C++在非面向对象方面对C语言的扩充
    2023-05-05
  • C++访问Redis的mset 二进制数据接口封装方案

    C++访问Redis的mset 二进制数据接口封装方案

    这篇文章主要介绍了C++访问Redis的mset 二进制数据接口封装方案的相关资料,需要的朋友可以参考下
    2015-07-07
  • C语言实现古代时辰计时与现代时间换算

    C语言实现古代时辰计时与现代时间换算

    这篇文章主要为大家详细介绍了如何利用C语言实现古代时辰计时与现代时间换算,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-03-03
  • Qt 进度条的实现示例

    Qt 进度条的实现示例

    进度条在很多时候都可以用到,有时我们需要在表格,树状栏中直观显示任务进度或消耗百分比,本文就详细的介绍一下Qt 进度条的使用实例,感兴趣的可以了解一下
    2021-06-06
  • C语言数据结构与算法之图的遍历(一)

    C语言数据结构与算法之图的遍历(一)

    这篇文章主要是介绍了利用深度优先算法实现图的遍历,文中利用图文详细的介绍了实现步骤,对我们学习数据结构与算法有一定的帮助,需要的朋友可以参考一下
    2021-12-12

最新评论