题解 | #争夺前五名#

争夺前五名

http://www.nowcoder.com/practice/cd052308a1c44a88ad00255f312c3e14

#include<stdio.h>
int main(void)
{
    int n;
    int score[150]={0};//根据数据量定义数组
    scanf("%d",&n);
    for(int i=0;i<n;i++)//输入的同时也做好排序
    {
        int scor;
        scanf("%d",&scor);//先把输入的数存到scor中
        getchar();//吸收掉空格符
        int l=i-1;//定义一个下标,用来定位scor在数组score中的合适位置
        while(l>=0&&scor>score[l])//如果不越界并且前面的数比它小,则继续往前比较
            l--;
        if(l!=i-1)//如果发现比我小的数的下标不是i的前一个,则说明需要重新调整排序
        {
            l=l+1;//因为l已经定位到了比scor大的下标,所以需要先将其往后挪一位
            int j;
            for(j=i;j>l;j--)//开始将i-1至l位置的数都往后挪一位
                score[j]=score[j-1];
            score[j]=scor;//将scor上的数插入到l位置上
         }
        else//如果发现我前面的i-1的这个数都比我大,则直接插入到i位置即可
            score[i]=scor;
    }//以上已经实现了,在输入的同时也做好了从大到小的排序
    
    for(int i=0;i<5;i++)
        printf("%d ",score[i]);
    return 0;
}
全部评论
你写的 真。。。 复杂。。。
点赞 回复 分享
发布于 2022-01-11 22:28
我是新手,别见怪哈
点赞 回复 分享
发布于 2022-01-22 16:38

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务