时间限制:1秒
空间限制:32768K
牛牛有一些字母卡片,每张卡片上都有一个小写字母,所有卡片组成一个字符串s。牛牛一直认为回文这种性质十分优雅,于是牛牛希望用这些卡片拼凑出一些回文串,但是有以下要求:
1、每张卡片只能使用一次
2、要求构成的回文串的数量最少
牛牛想知道用这些字母卡片,最少能拼凑出多少个回文串。
例如: s = "abbaa",输出1,因为最少可以拼凑出"ababa"这一个回文串
s = "abc", 输出3,因为最少只能拼凑出"a","b","c"这三个回文串
1、每张卡片只能使用一次
2、要求构成的回文串的数量最少
牛牛想知道用这些字母卡片,最少能拼凑出多少个回文串。
例如: s = "abbaa",输出1,因为最少可以拼凑出"ababa"这一个回文串
s = "abc", 输出3,因为最少只能拼凑出"a","b","c"这三个回文串
输入描述:
输入包括一行,一个字符串s,字符串s长度length(1 ≤ length ≤ 1000). s中每个字符都是小写字母
输出描述:
输出一个整数,即最少的回文串个数。
输入例子1:
abc
输出例子1:
3
题目链接:点击打开链接
分析:
我们可以对给出的字符串进行统计,因为题中要求最少的回文串个数,所以对于成偶数个的字符我们不做统计,因为都可以将他们放在一个回文串中,我们统计出有多少个字符是构成奇数个的,如果只有一个奇数个的字符的话,我们也可以将这个奇数字符放到偶数字符串中间,也能构成回文串,但是一个偶数回文串中只能添加一个含奇数个的字符串而不影响回文串的效果的,但是当奇数个的字符大于一的时候,最后组成的最少的回文串肯定是不同奇数字符的个数。
#include<iostream>
#include<stdio.h>
#include<string>
#include<math.h>
#include<string.h>
using namespace std;
int h[30];
int main()
{
char s[1005];
scanf("%s",s);
int len=strlen(s);
int sum;
for(int i=0;i<len;i++)
{
h[s[i]-'a']++;///字符当下标,统计字符的个数
}
int bj=0; ///统计奇数的字符个数
for(int i=0;i<26;i++)
{
if(h[i]%2)
bj++;
}
if(bj==1||bj==0)///如果没有奇数的字符串或者只有一个,那么最少的回文串肯定是1
sum=1;
else///否则得话,最少的回文串就是统计到的奇数的字符的个数
sum=bj;
printf("%d\n",sum);
return 0;
}