C++L13 统计数字(50 分)
- 一场歌唱比赛有不超过 26 位选手参加,
- 选手的代号依次用大写字母 A、B、C......表示。
- 在节目现场观众要给这些选手投票,每人投一票,选出最喜欢的选手。
- 已知观众的投票记录,请将所有选手的得票数从高到低进行排序。
例如:有 8 个观众,他们投票的记录是:D B C A D A D C。
其中 A 有 2 票,B 有 1 票,C 有 2 票,D 有 3 票。
得票数从高到低排序的结果是 3221。
- 输入:
共 2 行;
第 1 行是一个正整数 n(不大于 500):表示观众的人数;
第 2 行有 n 个字符:表示每个观众投票的选手代号:相邻两个字符用空格隔开。
题目数据保证每位选手至少有一票。
- 输出:
输出 1 行:有若干个整数,表示按选手得票数从高到低的排序结果,
相邻两个整数用一个空格隔开。
- 输入样例 1:
8
D B C A D A D C
- 输出样例 1:
3 2 2 1
cpp
#include<iostream>
#include<algorithm>
using namespace std;
int a[128]; //ASCII码表里有128个字符
int main(){//统计数字
int n;
cin>>n;
char m; //注意,输入的数据是字符类型
for(int i=0;i<n;i++){
cin>>m;
a[m]++; //以输入字符的码值作为下标
}
sort(a,a+128); //排序
for(int i=127;i>=0;i--) //从大到小所以倒序输出
if(a[i]) //只输出有值的元素
cout<<a[i]<<" ";
return 0;
}