试题编号:
1 | |
试题名称: | 出现次数最多的数 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: |
问题描述
给定n个正整数,找出它们中出现次数最多的数。如果这样的数有多个,请输出其中最小的一个。
输入格式
输入的第一行只有一个正整数n(1 ≤ n ≤ 1000),表示数字的个数。 输入的第二行有n个整数s1, s2, …, sn (1 ≤ si ≤ 10000, 1 ≤ i ≤ n)。相邻的数用空格分隔。
输出格式
输出这n个次数中出现次数最多的数。如果这样的数有多个,输出其中最小的一个。
样例输入
6 10 1 10 20 30 20
样例输出
10 |
思路:上学期学的C++的书本里,有要求用multiset和map来做题的,这道题恰好就可以用map
#include <iostream>
#include <map>
using namespace std;
int main()
{
int len, num, flag = 1, max = 0, num1;
map<int,int> mapnum;
map<int,int>::iterator iter;
cin >> len;
for (int i = 0; i < len; i++)
{
cin >> num;
for (iter = mapnum.begin(); iter != mapnum.end(); iter++)
{
if (num == iter->first)
{
iter->second = iter->second + 1;
flag = 0;
}
}
if (flag)
mapnum.insert(pair<int,int>(num,1));
flag = 1;
}
for (iter = mapnum.begin(), max = iter->second, num1 = iter->first; iter != mapnum.end(); iter++)
{
if (iter->second > max)
{
max = iter->second;
num1 = iter->first;
}
if (iter->second == max)
{
if (iter->first < num1)
num1 = iter->first;
}
}
cout << num1;
}