结构体对成绩进行排名

期末考试结束后要对同学们的考试成绩进行排序,张老师已经计算好了每一位同学的总成绩。请编写程序,输入每位同学的总成绩并输出一个按成绩高低排列的名次表。

该问题中,在成绩排序的同时,需要相应的学号和姓名一起随之变化。因此,我们可以使用结构体,学号、姓名、成绩以及名次作为结构体成员。通过对结构体对象成员(总成绩)的大小判断,实现把结构体对象作为一个整体进行排序操作。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
typedef struct student       //声明结构体 student
{      
    char id[5];      //学生学号(四位)
    char name[40];   //学生姓名
    float score;     //期末总成绩
    int num;         //名次
} student;     
 
int main(int argc, char *argv[])
{
    student stu[100], temp; //定义结构体对象数组 stu 和临时对象 temp
    int i, j, n;

    printf("输入学生人数(1~100):");
    scanf("%d", &n);
    printf("-----------------------\n");
    for (i = 0; i < n; i++) {  //输入学生成绩
        printf("学号输入9999则停止输入!\n");
        printf("学号(9999):"); 
        scanf("%s", stu[i].id);
        if (strcmp(stu[i].id, "-1") == 0) {
           n = i;
           break;
        }
        printf("姓名:"); 
        scanf("%s", stu[i].name);
        printf("总成绩:"); 
        scanf("%f", &stu[i].score);
    }
    for (i = 0; i < n; i++) { //按成绩排序(冒泡法)
        for (j = i+1; j < n; j++) {
            if (stu[i].score < stu[j].score) {
               temp = stu[i];
               stu[i] = stu[j];
               stu[j] = temp;
        }  //结构体变量整体交换
    }
        stu[i].num = i+1;
    }
    printf("----------------------------------\n");
    printf("  学号       姓名       成绩    名次\n");
    for (i = 0; i < n; i++) {   //输出名次
        printf("%6s",stu[i].id);
        printf("%10s",stu[i].name);
        printf("%12.2f",stu[i].score);
        printf("%6d\n",stu[i].num);
    }   
 
    return 0;
}

运行结果:

可以使用结构体数组来实现成绩排名。 首先,定义一个包含学生信息的结构体,例如: ```c struct student { char name[20]; int score; }; ``` 然后,定义一个结构体数组来存储所有学生的信息,例如: ```c struct student stu[100]; ``` 接下来,从用户输入中获取每个学生的姓名和成绩,并将其存储到结构体数组中。可以使用循环语句来实现: ```c int n; // n表示学生总数 for (int i = 0; i < n; i++) { printf("请输入第%d个学生的姓名和成绩:", i + 1); scanf("%s %d", stu[i].name, &stu[i].score); } ``` 接着,根据成绩进行排序。可以使用冒泡排序或选择排序来实现。这里以冒泡排序为例: ```c for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (stu[j].score < stu[j + 1].score) { struct student temp = stu[j]; stu[j] = stu[j + 1]; stu[j + 1] = temp; } } } ``` 最后,输出排名结果: ```c printf("排名结果如下:\n"); for (int i = 0; i < n; i++) { printf("第%d名:%s,成绩为%d\n", i + 1, stu[i].name, stu[i].score); } ``` 完整代码示例: ```c #include <stdio.h> struct student { char name[20]; int score; }; int main() { struct student stu[100]; int n; printf("请输入学生总数:"); scanf("%d", &n); for (int i = 0; i < n; i++) { printf("请输入第%d个学生的姓名和成绩:", i + 1); scanf("%s %d", stu[i].name, &stu[i].score); } for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (stu[j].score < stu[j + 1].score) { struct student temp = stu[j]; stu[j] = stu[j + 1]; stu[j + 1] = temp; } } } printf("排名结果如下:\n"); for (int i = 0; i < n; i++) { printf("第%d名:%s,成绩为%d\n", i + 1, stu[i].name, stu[i].score); } return 0; } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值