LCY买个n束花准备送给她暗恋的女生,但是他不知道这个女生是否喜欢他。这时候一个算命先生告诉他让他查花瓣数,第一个花瓣表示"爱",第二个花瓣表示"不爱",第三个花瓣表示"爱"…
为了使最后结果是"爱",LCY需要从n束花中选出一些,你能帮他算出最后他送给这个女生的花中最多包含多少个花瓣吗?
输入
首先输入一个整数T,表示测试实例的个数。
接下来T组测试实例,每组实例首先输入一行,包括一个整数n(1
<= n <= 100)。
然后输入一行,n个数a1,a2…an(1 <= ai <=
100),表示每束花包含的花瓣的个数。
输出
每组实例输出一个整数,表示LCY最多能送多少个花瓣给这个女生。
样例输入
3
1
1
1
2
3
5 6 7
样例输出
1
0
13
解析:
假设存在一个数m(即sum)
则存在三种情况:
**1.m为奇数,**此时直接输入sum值。
2.m为偶数,则m的组成情况可分为两种。不妨假设m是由i个奇数,j个偶数组成。
1.当i=0时,m都是由偶数组成的,最小奇数为初始值102,则无论卖多少都不行,输出0;
2.当i!=0,则必定是有偶数个奇数和j个偶数组成m,此时减去最小奇数,必为奇数;输出的sum必定为最大值。
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <algorithm>
using namespace std;
#define inf 0x3f3f3f3f
int a[100000];
int main()
{
int t;
cin>>t;
while(t--)
{
int n;
int min=inf,sum=0,ans=0;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>a[i];
if(a[i]%2!=0&&min>a[i])
{
min=a[i];
}
sum+=a[i];
if(a[i]%2!=0)
ans++;
}
if(sum%2!=0)
{
printf("%d\n",sum);
}
else
{
if(ans==0)
{
printf("0\n");
}
else
printf("%d\n",sum-min);
}
}
}