字符串完美度

題目詳情

我們要給每個字母配一個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 //提示:自動閱卷結束唯一標識,請勿刪除或增加。

代碼有點粗糙,但能理解這道題的做法就行了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章