-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy path10062.cpp
43 lines (36 loc) · 873 Bytes
/
10062.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# include <iostream>
using namespace std;
struct freq
{
char ch;
long int X ;
};
bool compare(freq A, freq B)
{
if (A.X>B.X)
return false;
else if (A.X<B.X)
return true;
else return (A.ch>B.ch);
}
int main()
{
char str[1005];
int start=0;
while(gets(str)!=NULL)
{
if (start)
cout<<endl;
else start=1;
freq arr[128]; int i;
for (int ch=0;ch<=127;ch++)
{ arr[ch].ch=ch;arr[ch].X=0;}
for(i=0;i<strlen(str);i++)
arr[str[i]].X++;
sort(arr,arr+128,compare);
for (i=0;i<128;i++)
if (arr[i].X>0)
cout<<(int)arr[i].ch<<" "<<arr[i].X<<endl;
}
return 0;
}