输入若干的字符串,每个字符串中只包含数字字符和大小写英文字母,统计字符串中有出现的不同字符的出现次数。
输入格式:
测试数据有多组,处理到文件尾。每组测试输入一个字符串(不超过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;
}