给出多个名字,计算每个名字最大可能的“漂亮度”。
首先题目没有明确说明漂亮度是什么
因此先给出两个说明:
1.漂亮度为每个字符的权重,为了让总和最大,出现次数越多的字符,漂亮度就越大。
2.输出的漂亮度只和当前输入的字符串有关,输入字符串不同,可以定义不同的字符漂亮度。
也就是说输入为aaaab时a的漂亮度为最大26,b的漂亮度为25,次大,当第二个字符串为bbbba时,又可以将b的漂亮度设置为26,a的漂亮度设置为25,因此输入字符串不同,可以由不同的漂亮度。
思路:
- 接收字符串
- 求每一个字符出现的次数
- 按出现的次数排序
- 设置字符漂亮度
- 输出总体漂亮度
代码
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
int num;
while(cin >> num)
{
string get;
while(num>0)
{
cin>>get;
num--;
vector<int> alp(26,0);
for(int i=0;i<get.size();i++)//忽略输入大小写,将输入都转化为大写
get[i]=toupper(get[i]);
for(int i=0;i<get.size();i++)
{
++alp[get[i]-'A'];
}
sort(alp.begin(),alp.end(),greater<int>());
int sum=0;
int index=0;
int num=26;
while(alp[index]!=0)
{
sum+=alp[index]*num;
index++;
num--;
}
cout<<sum<<endl;
}
}
return 0;
}
京公网安备 11010502036488号