期末考试结束后要对同学们的考试成绩进行排序,张老师已经计算好了每一位同学的总成绩。请编写程序,输入每位同学的总成绩并输出一个按成绩高低排列的名次表。
该问题中,在成绩排序的同时,需要相应的学号和姓名一起随之变化。因此,我们可以使用结构体,学号、姓名、成绩以及名次作为结构体成员。通过对结构体对象成员(总成绩)的大小判断,实现把结构体对象作为一个整体进行排序操作。
我们定义一个结构体对象的数组 stu 用来存放多个学生信息,每一个数组元素都是一个结构体对象:
struct student{
char id[5]; //学号
char name[40]; //姓名
float score; //期末总成绩
int num; //名次
}stu[100]; //定义一个结构体对象的数组stu
判断两个数组元素 stu[i] 和 stu[j] 中的结构体对象成员 stu[i].score 和 stu[j].score 的大小,从而决定是否交换数组元素 stu[i] 和 stu[j] 的值:
if(stu[i].score < stu[j].score){
temp = stu[i];
stu[i] = stu[j];
stu[j] = temp;
}
C语言代码清单 1:输入学生成绩并排列名次
#include <stdio.h>
#include <stdlib.h>
int main( )
{
struct student //声明结构体 student
{
char id[5]; //学生学号(四位)
char name[40]; //学生姓名
float score; //期末总成绩
int num; //名次
}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,"9999")==0){
n=i;
break;
}
printf("姓名:"); scanf("%s",&stu[i].name);
printf("总成绩:"); scanf("%f",&stu[i].score);
printf("-----------------------\n");
}
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("%+12s",stu[i].name);
printf("%10.2f",stu[i].score);
printf("%4d\n",stu[i].num);
}
system("pause");
return 0;
}
运行结果为:
输入学生人数(1~100):3
-----------------------
学号输入9999则停止输入!
学号(9999):1
姓名:lyy
总成绩:600
-----------------------
学号输入9999则停止输入!
学号(9999):2
姓名:syq
总成绩:605
-----------------------
学号输入9999则停止输入!
学号(9999):3
姓名:gmm
总成绩:550
-----------------------
----------------------------------
学号 姓名 成绩 名次
2 syq 605.00 1
1 lyy 600.00 2
3 gmm 550.00 3