0
点赞
收藏
分享

微信扫一扫

Redis篇---第七篇

googlefrank 2023-11-19 阅读 55

一.题目描述

在这里插入图片描述

题目大意:

题目链接:

二.思路分析

三.代码展示

//https://codeforces.com/contest/1899/problem/C
//首先需要判断奇偶,然后用sum存储当前序列的和,如果sum<0就重新计算(因为加上只会更小),求完和之后和之前的值进行比较,取最大的值
//
#include<iostream>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
#include<vector>
#include<cstring>
#define int long long
using namespace std;

int s[200020];

void solve()
{
    int n;
    cin>>n;
    int maxx=-1e9;
    for(int i=0;i<n;i++)
    {
    	cin>>s[i];
    	maxx=max(maxx,s[i]);
	}
	int sum=s[0];
	for(int i=1;i<n;i++)
	{
		if(sum<0||abs(s[i]%2)==abs(s[i-1]%2))
		{
			sum=s[i];
		}
		else
		{
			sum+=s[i];
		}
		maxx=max(maxx,sum);
	}
	cout<<maxx<<"\n";
}
signed main()
{
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	int t;
	cin>>t;
	while(t--)
	{
		solve();
	}
	return 0;
}



最后:

举报

相关推荐

0 条评论