马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
#include <stdio.h>
#define LEN 1001
int main(void)
{
int N;
int a[LEN],aa[LEN]={0};
int i,j,count;
scanf("%d",&N);
for(i=0;i<N;i++)
{
scanf("%d",&a[i]);
}
count = i;
for(i=0;i<count;i++)
{
for(j=0;j<count;j++)
{
if(a[i]==a[j])
{
aa[i]++;
}
}
}
int max = aa[0];
int num,biao_ji=0;
for(i=1;i<count;i++)
{
if(aa[i] > max)
{
num = a[i];
max = aa[i];
}
}
printf("%d %d",num,max);
return 0;
}
[color=var(--text-light)]7-5 求整数序列中出现次数最多的数 (15 分)
本题要求统计一个整型序列中出现次数最多的整数及其出现次数。 输入格式:输入在一行中给出序列中整数个数N(0<N≤1000),以及N个整数。数字间以空格分隔。 输出格式:在一行中输出出现次数最多的整数及其出现次数,数字间以空格分隔。题目保证这样的数字是唯一的。 输入样例:10 3 2 -1 5 3 4 3 0 3 2
输出样例:3 4题目要求如上,谢谢大家帮我看一下我的代码到底是哪里出了问题。QQ了。
你的代码应该只要不把最多次数的整数第一个输入就没多大问题了
至于出现这个bug的原因,你看如果你输入的数是依次是4 2 3 2 1的话,执行完 17到26行的循环后aa[0]和aa[2]的值就都变成2了
那,接下来如果一旦aa[0]的值是2的话, 重点来了 由于你27行让max=aa[0],那么32行的if就永远不会执行应为aa[i]的值最多也就是和aa[0]的值相等了,而如果if语句不执行的话,num的值也就相当于没被赋值所以最终会输出num的值位为0.
改的话直接将32行的>号改为>=号就行了。
最后,,如果满意的话别忘记设置最佳答案啊亲
|