码迷,mamicode.com
首页 > 其他好文 > 详细

HDU5744:Keep On Movin

时间:2016-07-22 01:00:10      阅读:222      评论:0      收藏:0      [点我收藏+]

标签:

题意:

给出t组测试数据,每组给出正整数n表示有n种字符,接下来给出n个数表示该种字符的数目,操作一下,使得可以构造的最小回文串字符数目最大且输出。


分析:

如果每个字符出现次数都是偶数, 那么答案显然就是所有数的和. 对于奇数部分, 显然需要把其他字符均匀分配给这写奇数字符. 随便计算下就好了。

即统计所有的字符的数目,奇数则-1再加上去,并且计数器count++,完成之后就输出数目,公式为字符数目=(sum/2)/count*2+1,其实就是平均了一下。


代码:

#include<cstdio>
#include<algorithm>
using namespace std;
int main(){
    int t;
    for(scanf("%d",&t);t--;){
        int sum1,sum2,n,num;
        sum1=sum2=0;scanf("%d",&n);    
        for(int i=0;i<n;i++){scanf("%d",&num);
        if(num&1) sum1++,sum2+=num-1; else sum2+=num;}
        printf("%d\n",(!sum1)?(sum2):((sum2/2)/sum1*2+1)); 
    }
} 

 

HDU5744:Keep On Movin

标签:

原文地址:http://www.cnblogs.com/chendl111/p/5693586.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!