c 最大子序列和_最大连续子序列

最大连续子序列:是指序列中所有子序列中元素和最大的一个

例如{-2,11,-4,13,-5.-2}中最大连续子序列为{11,-4,13}其和为20

若所有k个元素都为负数,则定义其最大和为0,输出整个序列的首尾元素

#include<iostream>

using namespace std;
//最大连续子序列:是指序列中所有子序列中元素和最大的一个
//例如{-2,11,-4,13,-5.-2}中最大连续子序列为{11,-4,13}其和为20
//若所有k个元素都为负数,则定义其最大和为0,输出整个序列的首尾元素
int main() {
	//在输入元素的过程中,一直记录负数的个数。
	int n,neg_num=0;
	int data[100];
	int start = 0, sum = 0, maxStart = 0, maxEnd = 0, maxSum = -1;
	cin >> n;
	for (int i = 0; i < n; i++) {
			cin >> data[i];
			//判断负数的个数
			if (data[i] < 0) neg_num++;
	}
	
	if (neg_num == n) {//均为负数,直接输出
		cout << "0" <<" "<< data[0]<<" " << data[n - 1] << endl;
	}
	//若序列中存在非负数
	else if (neg_num != n) {
		for (int i = 0; i < n; i++) {
			if (sum < 0) {
				start = i;
				sum = 0;
			}
			sum = sum + data[i];
			if (sum > maxSum) {
				maxStart = start;
				maxSum = sum;
				maxEnd = i;
			}
		}
		cout << maxSum << " " << data[maxStart] << " " << data[maxEnd] << endl;
	}
	return 0;
}

0d1fc231d304abaa4bbab5e97ed7cd32.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值