【题目描述】
给出一个含有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;
}

本文介绍了一个简单的算法,用于从一个包含n个整数的数组中找出出现次数超过一半的数。该算法首先初始化一个计数数组,然后遍历输入数组并更新计数数组。最后,再次遍历计数数组来确定是否存在满足条件的数。
&spm=1001.2101.3001.5002&articleId=80043298&d=1&t=3&u=ad36858bd7a04ed2a9fe01caa2ce6e5a)
1224

被折叠的 条评论
为什么被折叠?



