输入N个学生的英语分数,哪个分数出现的次数最多?如果有多个并列,从小到大输出。分数均为不超过100的非负整数。请使用循环和数组实现。

这段代码实现了一个冒泡排序算法,对输入的一组学生成绩进行升序排列,然后统计每个成绩出现的次数,找出出现次数最多的成绩并输出。
#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;
 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值