【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字

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;
}
相关推荐
一只鹿鹿鹿10 小时前
信息安全等级保护安全建设防护解决方案(总体资料)
运维·开发语言·数据库·面试·职场和发展
喵叔哟10 小时前
9. 【Blazor全栈开发实战指南】--Blazor调用JavaScript
开发语言·javascript·udp
wuqingshun31415910 小时前
如何停止一个正在退出的线程
java·开发语言·jvm
我命由我1234510 小时前
Element Plus - Form 的 resetField 方法观察记录
开发语言·前端·javascript·vue.js·html·html5·js
朱包林10 小时前
Python基础
linux·开发语言·ide·python·visualstudio·github·visual studio
卷福同学10 小时前
QClaw内测体验,能用微信指挥AI干活了
人工智能·算法·ai编程
sali-tec10 小时前
C# 基于OpenCv的视觉工作流-章34-投影向量
图像处理·人工智能·opencv·算法·计算机视觉
xiaoye-duck10 小时前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂
数据结构·c++·算法·递归
Eward-an10 小时前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析
python·算法·leetcode·面试·职场和发展
山栀shanzhi10 小时前
归并排序(Merge Sort)原理与实现
数据结构·c++·算法·排序算法