本文主要是介绍CCF - 201312-1 - 出现次数最多的数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
问题描述
试题编号: | 201312-1 |
试题名称: | 出现次数最多的数 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: | 问题描述 给定n个正整数,找出它们中出现次数最多的数。如果这样的数有多个,请输出其中最小的一个。 输入格式 输入的第一行只有一个正整数n(1 ≤ n ≤ 1000),表示数字的个数。 输出格式 输出这n个次数中出现次数最多的数。如果这样的数有多个,输出其中最小的一个。 样例输入 6 样例输出 10 |
思路
看似统计问题,问题在于如何统计。方法有二: 一是使用STL的map进行统计,是比较有效的办法。在同值的数比较多时,可以节省空间。 二是由于si介于1和10000之间,所以可以用一个数组进行统计。
代码
#include<stdio.h>
#include<string.h>
int main()
{int i,n,a[10001],b,max,maxc;scanf("%d",&n);memset(a,0,sizeof(a));for(i=1;i<=n;i++){scanf("%d",&b);a[b]++;}max=1;maxc=0;for(i=1;i<=10000;i++){if(a[i]>maxc){maxc=a[i];max=i;}}printf("%d\n",max);return 0;
}
#include<iostream>
#include<map>
using namespace std;
int main()
{int i,n,b,max,maxc;map<int,int>a;scanf("%d",&n);for(i=1;i<=n;i++){scanf("%d",&b);a[b]++;}max=1;maxc=0;for(map<int,int>::iterator it=a.begin();it!=a.end();it++){if(it->second>maxc){maxc=it->second;max=it->first;}}printf("%d\n",max);return 0;
}
这篇关于CCF - 201312-1 - 出现次数最多的数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!