題目詳情
我們要給每個字母配一個1-26之間的整數,具體怎麼分配由你決定,但不同字母的完美度不同,
而一個字符串的完美度等於它裏面所有字母的完美度之和,且不在乎字母大小寫,也就是說字母F和f的完美度是一樣的。
現在給定一個字符串,輸出它的最大可能的完美度。
例如:dad,你可以將26分配給d,25分配給a,這樣整個字符串最大可能的完美度爲77。
函數頭部
C
int perfect(const char *s);
C++
int perfect(const string &s);
java
public static int perfect(String s);
算法描述
題目比較簡單,先把字符串都變成大寫或者小寫,然後依次找出出現次數最多的字母,然後最多的分26,次多的分25,依次類推,最後求和。
直接上代碼了。
#include <cstdio> #include <cstring> #include <string> #include <algorithm> using namespace std; void QuickSort(int next[26],int low,int high,int size){ int i = low; int j = high; int temp; if(i < j){ temp = next[low]; while(i < j){ while(j > i && next[j] <= temp) j--; next[i] = next[j]; while(i < j && next[i] >= temp) i++; next[j] = next[i]; } next[i] = temp; QuickSort(next,low,i-1,size); QuickSort(next,i+1,high,size); } } void QuickSortDC(int next[26],int low,int high,int size){ QuickSort(next,low,high,size); } void transform(string &str) { for(int i=0;i<str.length();i++){ if(islower(str[i])) str[i] = str[i]-32; } } int perfect(const string &s) { string str = s; int count[26]; for(int i=0;i<26;i++) count[i] = 0; transform(str); for(int k=0;k<str.length();k++){ count[str[k]-65]++; } QuickSortDC(count,0,25,26); int j=26; int sum=0; for(int x=0;x<26;x++){ if(count[x] != 0){ sum+=count[x]*j; j--; } } return sum; } //start 提示:自動閱卷起始唯一標識,請勿刪除或增加。 int main() { } //end //提示:自動閱卷結束唯一標識,請勿刪除或增加。
代碼有點粗糙,但能理解這道題的做法就行了。