学生成绩排名(C语言编写)

来源:互联网 发布:获取intent数据 编辑:程序博客网 时间:2024/05/19 20:40

//学生成绩排名

#include <stdio.h>


struct Birthday{    

    int year;

    int month;

    int day;

    };


struct Student{

        char name[30];

    int age;

    structBirthday birthday;

    double score;

    };



int main() {

    int x;

    printf("请输入学生人数:\n");

    scanf("%d", &x);

    

    struct Student stu[x];

    struct Student *p = stu;

    

    printf("请输入学生的姓名年龄出生年成绩:\n");

    

    for(int i = 0; i < x; i++){

        scanf("%s%d%d%d%lf",\

              (*(p+i)).name,\

              &(*(p+i)).age, \

              &(*(p+i)).birthday.year,\

              &(*(p+i)).birthday.month, \

              &(*(p+i)).score);

           }

    

// 用数组b[z]接收所有学生的成绩

    double b[x];

    for (int z = 0; z < x; z++) {

        b[z] = (*(p+z)).score;

    }

    

 //将所有学生的成绩重新排列,从b[0]开始依次减小(重复的排在一起)

    for(int i = 0; i < x; i++){

        for (int m = i+1; m < x; m++) {

            if (b[i] < b[m]) {

                int temp = b[i];

                b[i] = b[m];

                b[m] = temp;

            }         //i = 0时,将最大的排到b[0],以此类推

        }

    }


    int t;

//用来记录重复成绩的个数

    for (int j =0; j < x; j += t) {              //j+=t,既去除了b[j]后面(t-1)与之重复的的成绩

        t = 0;              //每次都从0开始记录,否则不是同一个成绩的重复个数,而是所有的打印出来的个数

        for (int i =0; i < x; i++) {

            if((*(p+i)).score == b[j]) {

                //(*(p+i))每次都是从第一个开始与固定的成绩比较,这样使已经比较出来的进行了重复比较,需要考虑怎么去除掉这些重复比较

                //b[j],因为数组b[j]收集了所有学生的成绩,并且将所有的成绩进行了排列,从b[0]开始依次减小(相同的成绩排在一起),所以从b[0]开始选择成绩最好的,以此类推

                printf("名次%d  %s成绩为%.2f,生日是%d%d\n",\

                       j+1,

                       (*(p+i)).name, \

                       (*(p+i)).score, \

                       (*(p+i)).birthday.year, \

                       (*(p+i)).birthday.month);

                t++;           //去除b[j]中重复的,如果只有一个成绩等于b[j],t++ 1,进入下一个b[j+1],如果有n个成绩等于b[j],t++ = n+1,则进入b[j+n+1],从而过滤掉前几个重复的

                }

            }

        }

        

    return 0;

}





0 0
原创粉丝点击