J.H


私信TA

用户名:dotcpp0649969

访问量:5224

签 名:

等  级
排  名 80
经  验 9564
参赛次数 1
文章发表 135
年  龄 0
在职情况 学生
学  校 桂林理工大学
专  业 计算机科学与技术

  自我简介:

TA的其他文章

解题思路:

注意事项:

参考代码:

#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 人评分

  评论区

  • «
  • »