51Nod_1182 完美字符串
http://www.51nod.com/Challenge/Problem.html#!#problemId=1182
题目
约翰认为字符串的完美度等于它里面所有字母的完美度之和。每个字母的完美度可以由你来分配,不同字母的完美度不同,分别对应一个1-26之间的整数。约翰不在乎字母大小写(也就是说字母A和a的完美度相同)。给定一个字符串,输出它的最大可能的完美度。例如:dad,你可以将26分配给d,25分配给a,这样整个字符串完美度为77。
输入
输入一个字符串S(S的长度 <= 10000),S中没有除字母外的其他字符。
输出
由你将1-26分配给不同的字母,使得字符串S的完美度最大,输出这个完美度。
样例输入
dad
样例输出
77
分析
贪心法水题,数量越多的字母分配的完美度越大
C语言程序
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
char s[10005];
int cmp(const void *a,const void *b)
{
return *((int*)a)-*((int*)b);
}
int main()
{
int a[26]={0};
scanf("%s",s);
strlwr(s);//全部字母变为小写
for(int i=0;i<strlen(s);i++)
a[s[i]-'a']++;
qsort(a,26,sizeof(int),cmp);//排序
int sum=0;
for(int i=25,w=26;i>=0;i--)
sum+=w*a[i],w--;
printf("%d\n",sum);
return 0;
}