#include<stdio.h>
int main ()
{
int i,j,t,N,n,max=0;
int mat[300],mat_new[300];
scanf("%d",&N); //输入总输入个数
for (i=0;i<N;i++) //输入学生成绩
scanf("%d",&mat[i]);
for (i=0;i<N;i++) //让每一个计数器都为1
mat_new[i]=1;
for (i=0;i<=N-1;i++) //以下为冒泡法先排序
for(j=0;j<N-i-1;j++)
if (mat[j]>mat[j+1])
{
t=mat[j+1];
mat[j+1]=mat[j];
mat[j]=t;
}
for (i=0;i<N;i++) //计数器计数 从被记数的下一个数开始记
for (j=0;j<N;j++)
{
if(j<=i) continue;
if(mat[i]==mat[j]) mat_new[i]=mat_new[i]+1;
}
for (i=0;i<N;i++) //遍历mat_new数组,找到最大的次数
if (mat_new[i]>max)
max=mat_new[i];
for (i=0;i<N;i++) //找到在mat中对应序号为max的数值
if (mat_new[i]==max)
{
printf("%d ",mat[i]);
// printf(" ");
}
return 0;
}
输入N个学生的英语分数,哪个分数出现的次数最多?如果有多个并列,从小到大输出。分数均为不超过100的非负整数。请使用循环和数组实现。
于 2022-03-31 20:19:27 首次发布
