题目 #
有如下表所示的成绩单:
- 请建立合适的结构,并从键盘输入表中的数据,求出每名同学的平均分;
- 按照平均分成绩由高到低对表中的数据进行排序。
- 计算并输出每一门课程的平均分。
Name |
sex |
English |
Math |
Programming |
Zhaolin |
M |
80 |
70 |
50 |
Qianming |
F |
90 |
80 |
70 |
Sunwen |
F |
70 |
70 |
80 |
Liyuan |
M |
60 |
50 |
60 |
Liuli |
F |
70 |
90 |
70 |
解决方案 #
这里我提示一下,当你结束输入的时候按两次 ctrl + z
下面是我的程序和运行的结果
#include
struct ln
{
char name[20];//姓名
char sex[2];//性别
float enscore;//英语分
float mascore;//数学分
float prscore;//程序设计分
float avg;//平均分
}student[1000];//假设上限为1000名学生
int create()//返回输入学生的人数{
int i=0;
char name[20];
printf("请输入学生的姓名,性别,英语分,数学分,程序设计分\n");
printf(" 按ctrl + z 结束输入\n");
while(scanf("%s", name)!=EOF)
{
strcpy(student[i].name, name);
scanf("%s %f %f %f", student[i].sex, &student[i].enscore, &student[i].mascore, &student[i].prscore);
student[i].avg = (student[i].enscore + student[i].mascore + student[i].prscore)/3.0;
i++;
}
printf("录入完成\n\n");
return i;
}
int cmp(const void *p, const void *q){
return (*(struct ln *)q).avg - (*(struct ln *)p).avg;
}
void avgstudent(int n)//按学生的平均分进行排序,,参数为学生的人数{
int i;
qsort(student, n, sizeof(struct ln), cmp);//用快排进行排序
printf("\n 按平均分排序后\n\n");
printf("name sex English Math Programming avg\n\n");
for(i=0; iprintf("%-15s%-5s%-10.2f%-10.2f%-10.2f%-10.2f\n", student[i].name, student[i].sex, student[i].enscore, student[i].mascore, student[i].prscore, student[i].avg);
}
}
void avgsubject(int n)//计算每个科目的平均分{
float Englishsum=0, Mathsum=0, Programmingsum=0;//每个学科的总分
int i;
for(i=0; iprintf("\n 各学科的平均分\n\n");
printf("Mathavg = %-10.2fEnglishavg = %-10.2fProgrammingavg = %-10.2f\n", Englishsum/n, Mathsum/n, Programmingsum/n);
}
int main(){
int n;
n = create();
system("pause");
avgstudent(n);
system("pause");
avgsubject(n);
}
评论