解题思路:

注意事项:

参考代码:

#include<stdio.h>

#include<math.h>


struct student

{

    int id;

    int score;

};


int main()

{

    struct student x[5000];

    int n, m, line, i, j, sum = 0;

    scanf("%d %d", &n, &m);

    line = floor((double)m * 1.5);


    // 输入每个学生的报名号和笔试成绩

    for (i = 0; i < n; i++)

        scanf("%d %d", &x[i].id, &x[i].score);


    // 根据成绩和报名号排序学生信息

    for (i = 0; i < n - 1; i++)

    {

        for (j = 0; j < n - i - 1; j++)

        {

            if (x[j].score < x[j + 1].score)

            {

                struct student temp;

                temp = x[j];

                x[j] = x[j + 1];

                x[j + 1] = temp;

            }

            else if (x[j].score == x[j + 1].score && x[j].id > x[j + 1].id)

            {

                struct student temp;

                temp = x[j];

                x[j] = x[j + 1];

                x[j + 1] = temp;

            }

            else if (x[i].score == x[j + 1].score && x[j].id == x[j + 1].id)

                continue;

        }

    }


    // 输出面试分数线

    printf("%d ", x[line - 1].score);


    // 计算进入面试的学生人数

    for (i = 0; i < n; i++)

    {

        if (x[i].score >= x[line - 1].score)

        {

            sum++;

        }

        else

        {

            break;

        }

    }


    // 输出进入面试的学生人数

    printf("%d\n", sum);


    // 输出进入面试的学生的报名号和成绩

    for (i = 0; i < sum; i++)

    {

        printf("%d %d\n", x[i].id, x[i].score);

    }


    return 0;

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论