c/c++编程题 之 求数组的子数组之和的最大值

这是一道编程题,目标是找出数组中的子数组,使其元素之和达到最大值。题目对时间限制和内存使用进行了规定,并提供了提交、统计和提问的功能。

求数组的子数组之和的最大值


时间限制:1 Sec 内存限制:128 MB
提交:85 正确:14

[ 提交 ] [ 统计 ] [ 提问 ]

题目描述

对于任意给定的整数数组,求其子数组之和的最大值。(子数组表示连续元素构成的序列)

输入描述

输入数组长度及数组的元素值

输出描述

子数组元素之和的最大值

输入样例

6
1 -2 3 5 -3 2

输出样例

8

AC代码如下:
#include<iostream>  
using namespace std;  
#include<string.h>  
using namespace std;  
int main()  
{  
    int j,sum,a,n,max,z;  
	cin>>n;  
	for(sum=0,max=-1001,j=0;j<n;j++)  
	{  
		cin>>a;  
		sum+=a;  
		if(max<sum)  
		{   
			max=sum;  
		}  
		if(sum<0)  
		{   
			sum=0;  
		}  
	}  
	cout<<max<<endl;  
	return 0;
}  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值