标签:
输入一个字符串S(S的长度 <= 10000),S中没有除字母外的其他字符。
由你将1-26分配给不同的字母,使得字符串S的完美度最大,输出这个完美度。
dad
77
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> using namespace std; char a[10005]; int res[30]; int n; long long ans=0; int maxn=-1; int max(int a,int b) { if(a>b)return a; else return b; } int main() { scanf("%s",a+1); n=strlen(a+1); int pos=1; int QAQ=26; for(int i=1;i<=n;++i) { if(a[i]>=‘a‘&&a[i]<=‘z‘)res[a[i]-‘a‘]++; else res[a[i]-‘A‘]++; } while(n) { for(int i=0;i<26;++i) { if(maxn<=res[i]) { maxn=res[i]; pos=i; } } n--; res[pos]=0; ans+=maxn*QAQ; QAQ--; maxn=-1; } cout<<ans; puts(""); return 0; }
由排序不等式,出现次数最多的字母显然应该给26。所以这个题目变成了统计每种字母出现的次数了,然后按照出现次数从大到小,依次分配从高到低的权值。这就是最朴素的贪心思想。
标签:
原文地址:http://www.cnblogs.com/gc812/p/5916256.html