網(wǎng)站首頁 編程語言 正文
例題
題目:輸入一個整形數(shù)組,數(shù)組里有正數(shù)也有負(fù)數(shù)。數(shù)組中連續(xù)的一個或多個整數(shù)組成一個子數(shù)組,每個子數(shù)組都有一個和。求所有子數(shù)組的和的最大值。要求時間復(fù)雜度為O(n)。
例如輸入的數(shù)組為1, -2, 3, 10, -4, 7, 2, -5,和最大的子數(shù)組為3, 10, -4, 7, 2,因此輸出為該子數(shù)組的和18。
1.求最大的子數(shù)組的和
代碼【C++】
#include <iostream>
using namespace std;
/
// Find the greatest sum of all sub-arrays
// Return value: if the input is valid, return true, otherwise return false
/
bool FindGreatestSumOfSubArray
(
int *pData, // an array
unsigned int nLength, // the length of array
int &nGreatestSum // the greatest sum of all sub-arrays
)
{
// if the input is invalid, return false
if((pData == NULL) || (nLength == 0))
return false;
int nCurSum = nGreatestSum = 0;
for(unsigned int i = 0; i < nLength; ++i)
{
nCurSum += pData[i];
// if the current sum is negative, discard it
if(nCurSum < 0)
nCurSum = 0;
// if a greater sum is found, update the greatest sum
if(nCurSum > nGreatestSum)
nGreatestSum = nCurSum;
}
// if all data are negative, find the greatest element in the array
if(nGreatestSum == 0)
{
nGreatestSum = pData[0];
for(unsigned int i = 1; i < nLength; ++i)
{
if(pData[i] > nGreatestSum)
nGreatestSum = pData[i];
}
}
return true;
}
int main()
{
int arr[] = {1, -2, 3, 10, -4, 7, 2, -5};
int iGreatestSum;
FindGreatestSumOfSubArray(arr, sizeof(arr)/sizeof(int), iGreatestSum);
cout << iGreatestSum << endl;
return 0;
}
結(jié)果
2.求和最大的相應(yīng)子數(shù)組
代碼【C++】
#include <iostream>
using namespace std;
/
// Find the greatest sum of all sub-arrays
// Return value: if the input is valid, return true, otherwise return false
/
bool FindGreatestSumOfSubArray
(
int *pData, // an array
unsigned int nLength, // the length of array
int &nGreatestSum, // the greatest sum of all sub-arrays
int &start, // Added
int &end // Added
)
{
// if the input is invalid, return false
if((pData == NULL) || (nLength == 0))
return false;
int nCurSum = nGreatestSum = 0;
int curStart = 0, curEnd = 0; // Added
start = end = 0; // Added
for(unsigned int i = 0; i < nLength; ++i)
{
nCurSum += pData[i];
curEnd = i; // Added
// if the current sum is negative, discard it
if(nCurSum < 0)
{
nCurSum = 0;
curStart = curEnd = i + 1; // Added
}
// if a greater sum is found, update the greatest sum
if(nCurSum > nGreatestSum)
{
nGreatestSum = nCurSum;
start = curStart; // Added
end = curEnd; // Added
}
}
// if all data are negative, find the greatest element in the array
if(nGreatestSum == 0)
{
nGreatestSum = pData[0];
start = end = 0; // Added
for(unsigned int i = 1; i < nLength; ++i)
{
if(pData[i] > nGreatestSum)
{
nGreatestSum = pData[i];
start = end = i; // Added
}
}
}
return true;
}
int main()
{
int arr[] = {1, -2, 3, 10, -4, 7, 2, -5};
int iGreatestSum, start, end;
FindGreatestSumOfSubArray(arr, sizeof(arr)/sizeof(int), iGreatestSum,
start, end);
cout << iGreatestSum << ": ";
for(int i = start; i <= end; i++)
{
cout << arr[i] << " ";
}
return 0;
}
結(jié)果
原文鏈接:https://blog.csdn.net/weixin_55764157/article/details/124417096
相關(guān)推薦
- 2022-05-10 thymeleaf跳轉(zhuǎn)到響應(yīng)頁面(modelandview 中的view)
- 2022-08-07 Redis如何存儲對象_Redis
- 2022-02-17 不懂就問:map中使用await為什么會失效?
- 2023-05-03 C++11學(xué)習(xí)之包裝器解析_C 語言
- 2022-06-18 Android實(shí)現(xiàn)背景圖滑動變大松開回彈效果_Android
- 2022-11-02 使用ggsignif優(yōu)雅添加顯著性標(biāo)記詳解_R語言
- 2022-08-03 python中filter,map,reduce的作用_python
- 2022-11-01 如何將asp.net?core程序部署到Linux服務(wù)器_實(shí)用技巧
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支