天天看點

7-33 統計字元個數 (10 分)

輸入若幹的字元串,每個字元串中隻包含數字字元和大小寫英文字母,統計字元串中有出現的不同字元的出現次數。

輸入格式:

測試資料有多組,處理到檔案尾。每組測試輸入一個字元串(不超過80個字元)。

輸出格式:

對于每組測試,按字元串中有出現的字元的ASCII碼升序逐行輸出不同的字元及其個數(兩個資料之間留一個空格),每兩組測試資料之間留一空行,輸出格式參照輸出樣例。

輸入樣例:

12123
A1c1B
           

輸出樣例:

1 2
2 2
3 1

1 2
A 1
B 1
c 1
           
#include <iostream>
using namespace std;
int main(){//7-33 統計字元個數 (10 分)
    string s;
    int flag=0;
    while(cin>>s){
          if(flag==1) cout<<endl;
        int arr[10]={0},brr[26]={0},crr[26]={0};
        int len=s.length();
        for(int i=0;i<len;i++){
            if(s[i]>='0'&&s[i]<='9'){
                arr[s[i]-'0']++;
            }else{
                if(s[i]>='a'&&s[i]<='z'){
                    brr[s[i]-97]++;
                }else{
                    crr[s[i]-65]++;
                }
            }
        }
        for(int i=0;i<10;i++){
            if(arr[i]!=0){
                cout<<i<<" "<<arr[i]<<endl;
            }
        }
        for(int j=0;j<26;j++){
            if(crr[j]!=0){
                printf("%c",j+65);
                cout<<" "<<crr[j]<<endl;
            }
        }
        for(int k=0;k<26;k++){
            if(brr[k]!=0){
                printf("%c",k+97);
                cout<<" "<<brr[k]<<endl;
            }
        }
      flag=1;
    }
    
    return 0;
}
           
7-33 統計字元個數 (10 分)