题解 | #争夺前五名#

争夺前五名

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

纠正一下,这是降序排布。

#include <stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    int score[n];

    int i;
    int mark = 0;
    //数组赋值
    for(i = 0;i < n;i++)
    {
        scanf("%d",&mark);
        score[i] = mark;
    }
    //降序排布
    for(i = 1;i < n;i++)
    {
        int temp = 0;   //中转变量
        int j;
        for(j = 0;j < i;j++)    //score[1]比较score[0],向前比较 i 次
        {
            if(score[i] >= score[j])    //利用中转变量,当后者大于前者交换
            {
                temp = score[j];
                score[j] = score[i];
                score[i] = temp;
            }
        }
    }
    //打印前五
    for(i = 0;i < 5;i++)
    {
        printf("%d ",score[i]);
    }
    return 0;
}

全部评论

相关推荐

牛客868257804号:九个中铁八个中建
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-20 19:57
已编辑
某大厂 golang工程师 23.0k*16.0, 2k房补,年终大概率能拿到
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务