试题编号: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个整数s 1, s 2, …, s n (1 ≤ s i ≤ 10000, 1 ≤ i ≤ n)。相邻的数用空格分隔。
输出格式
输出这n个次数中出现次数最多的数。如果这样的数有多个,输出其中最小的一个。
样例输入
6
10 1 10 20 30 20
10 1 10 20 30 20
样例输出
10
#include <iostream>
#include <algorithm>
#include <string.h>
using namespace std;
#define N 10000
int s[N + 1];
int main(void)
{
int n,i,a,max,b; //b是最后结果
scanf("%d",&n);
memset(s,0,sizeof(s));
for(i=0;i<n;i++){
scanf("%d",&a);
s[a]++;
}
max = INT_MIN;
b = -1;
for(i=1;i<=N;i++){
if(s[i] > max){ //因为这是从小到大排序的,所以,直接用大于,不用大于等于,很巧妙啊
max = s[i];
b = i;
}
}
printf("%d\n",b);
return 0;
}