博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CCF201312-1 出现次数最多的数(100分)
阅读量:5960 次
发布时间:2019-06-19

本文共 1617 字,大约阅读时间需要 5 分钟。

试题编号: 201312-1
试题名称: 出现次数最多的数
时间限制: 1.0s
内存限制: 256.0MB
问题描述:
问题描述
  给定n个正整数,找出它们中出现次数最多的数。如果这样的数有多个,请输出其中最小的一个。
输入格式
  输入的第一行只有一个正整数n(1 ≤ n ≤ 1000),表示数字的个数。
  输入的第二行有n个整数s
1, s
2, …, s
n (1 ≤ s
i ≤ 10000, 1 ≤ i ≤ n)。相邻的数用空格分隔。
输出格式
  输出这n个次数中出现次数最多的数。如果这样的数有多个,输出其中最小的一个。
样例输入
6
10 1 10 20 30 20
样例输出
10

问题链接:

问题描述:首先输入正整数n,接着输入n个正整数,求出其中出现次数最多的,如果出现次数相同则求出最小的那个。

问题分析

看似统计问题,问题在于如何统计。方法有二:

一是使用STL的map进行统计,是比较有效的办法。在同值的数比较多时,可以节省空间。

二是由于si介于1和10000之间,所以可以用一个数组进行统计。

程序说明

这里写了C语言和C++语言两个版本的程序。

C语言程序逻辑相对比较简洁。

C++语言程序是一个典型的应用STL容器类的实例。

提交后得100分的C语言程序如下:

/* CCF201312-1 出现次数最多的数 */#include 
#include
#define N 10000int sicount[N + 1];int main(void){ int n, v, i; // 变量初始化 memset(sicount, 0, sizeof(sicount)); // 输入数据,进行统计 scanf("%d", &n); while(n--) { scanf("%d", &v); sicount[v]++; } // 找出出现次数最多的数 int ans, maxcount=0; for(i=1; i<=N; i++) { if(sicount[i] > maxcount) { ans = i; maxcount = sicount[i]; } } // 输出结果 printf("%d\n", ans); return 0;}

提交后得100分的程序如下:

/* CCF201312-1 出现次数最多的数 */#include 
#include
using namespace std;int main(){ map
m; int n, v; // 输入数据,构建Map cin >> n; for(int i=0; i
> v; m[v]++; } // 找出出现次数最多的数 int ans, count=0; for(map
::iterator it=m.begin(); it!=m.end(); it++) if(it->second > count) { count = it->second; ans = it->first; } // 输出结果 cout<
<

转载于:https://www.cnblogs.com/tigerisland/p/7564237.html

你可能感兴趣的文章
xshell能ping通虚拟机,不能连接虚拟机
查看>>
任意层级树型数据的遍历和过滤
查看>>
iOS 防止反编译加密方法
查看>>
微信小程序开发的一点心得
查看>>
关于用nodejs编写管理系统
查看>>
深入理解node stream机制及其实现原理
查看>>
JavaScript 中错误正确处理方式,你用对了吗?
查看>>
分辨率,dpi,dp,与最终显示大小的四角关系
查看>>
JavaSE基础:抽象类
查看>>
Android实战 粗略实现一个简单的C S结构聊天室的功能
查看>>
购物车原理以及实现
查看>>
浅探webpack优化
查看>>
ReactNative与iOS的交互
查看>>
v-model 是怎么实现的?
查看>>
习惯不同语言以太坊开发者可选择客户端
查看>>
面试题:浏览器从输入URL到渲染
查看>>
JavaScript函数式编程,真香之组合函数(二)
查看>>
Java 集合(2)之 Iterator 迭代器
查看>>
Android MVVM组件化架构方案
查看>>
学汉语、来云栖、海外布道阿里云……这位印度架构师不一般
查看>>