一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C++如何求連續幾個數之和的最大值

C++如何求連續幾個數之和的最大值

2020-12-11 15:40C++教程網 C/C++

本篇文章是對如何求連續幾個數之和的最大值進行了詳細的分析介紹,需要的朋友參考下

給定一組數,有正有負,求連續的幾個數之和的最大值?并求出是從第幾個數開始,第幾個數結束?如果有多個序列可組成相同的最大值,則選取最開始的一個序列。(注:這兩天看《編程之美》,發現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/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
主站蜘蛛池模板: 亚洲天堂2015 | 胸大的姑娘中文字幕视频 | 欧美男人天堂 | 和直男装修工在工地啪 | 美女尿口羞羞视频 | 国产91精品在线观看 | 日本小网站 | 青草碰人人澡人人澡 | 久久久久激情免费观看 | 四虎四虎| 岛国片免费观看 | 国产探花视频在线观看 | 亚洲精品福利你懂 | 99视频在线免费观看 | 国产福利一区二区在线精品 | 亚洲精品AV无码喷奶水糖心 | 亚洲国产欧美另类va在线观看 | 久久综合久综合久久鬼色 | 亚洲国产韩国欧美在线不卡 | 免费看3d小舞被躁视频网站 | 国产精品www | 情缘1完整版在线观看 | a男人天堂| 免费91麻豆精品国产自产在线观看 | 99久热只有精品视频免费观看17 | 四虎影院在线免费播放 | 91视频国产一区 | 国产精品自拍一区 | 欧美调教打屁股spank视频 | 国产精品麻豆 | 三极黄色 | 99久久香蕉国产线看观香 | 日本aa大片在线播放免费看 | 情人梁家辉在线 | 国产激情视频 | 无遮挡免费h肉动漫在线观看 | 500福利第一巨人导航 | 亚洲精品久久久久AV无码 | 久久这里只有精品无码3D | 亚洲欧美另类综合 | 桃色视频软件 |