【题目描述】
给出一个含有n(0 < n ≤ 1000)个整数的数组,请找出其中出现次数超过一半的数。数组中的数大于-50且小于50。
【输入】
第一行包含一个整数n,表示数组大小;
第二行包含n个整数,分别是数组中的每个元素,相邻两个元素之间用单个空格隔开。
【输出】
如果存在这样的数,输出这个数;否则输出no。
【输入样例】
3
1 2 2【输出样例】
2
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{
int a[101]={0};
int n,b;
int i;
bool flag=false;
cin>>n;
for(i=0;i<n;i++)
{
cin>>b;
a[b+50]++;
}
for(i=0;i<100;i++)
{
if(a[i]>=n/2)
{
flag=true;
cout<<i-50<<endl;
}
}
if(flag==0)
cout<<"no";
cout<<endl;
return 0;
}
信息学奥赛一本通T1186:数据排序 出现次数超过一半的数 归属于 数据排序,更多同类题解源程序见:数据排序 和 出现次数超过一半的数
0 篇文章
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!