PAT(甲级)1007 (简单最大序列和)

由于题中只要求了subsequence 子序列的最大和(不是子串),那么这道题就不用做得太麻烦了。
简单维护一下最大不定前缀和即可。
坑点:题中只说全负数时直接取零,这意味着在序列中出现0是要记录的。

学习到了:
1、以后还是多注意下读题吧。多读一分钟,节约找bug时间10分钟。。。
2、第一次使用scanf(), 在PAT的诡异测评机下居然报警告!解决办法是
if(scanf()) {}

#include<iostream>
#include<vector>
using namespace std;
int main(void)
{
	int n;
	if (scanf("%d", &n)) {};
	vector<int> a(n);
	for (int i = 0; i < n; i++)
	{
		if (scanf("%d", &a[i])) {};
	}
	int maxSum = -1, sum = 0;
	int ind_s = 0, st = 0;
	int ind_e = n-1 , ed = n-1;
	for (int i = 0; i < n; i++)
	{
		if (!sum) st = i;
		sum += a[i];
		if (sum < 0)
		{
			sum = 0;
			continue;
		}
		ed = i;
		if (sum > maxSum)
		{
			maxSum = sum;
			ind_s = st;
			ind_e = ed;
		}
	}
	printf("%d %d %d\n", ~maxSum?maxSum:0, a[ind_s], a[ind_e]);
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值