欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

最大连续子序列

程序员文章站 2022-04-11 19:00:55
...
  • 最大连续子序列:是指序列中所有子序列中元素和最大的一个
    例如{-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;
}

最大连续子序列