#include<stdio.h>
void pai(int m[],int size);
struct student{
char ming[25];
char hao[25];
int score[6];
double pingshi;
int total;
}stu;
int main()
{
struct student * st=&stu;
gets(stu.ming);
gets(stu.hao);
for(int i=0;i<5;i++)
{scanf("%d",&stu.score[i]);
stu.total+=stu.score[i];}
pai(st->score,5);
printf("Name:");
puts(st->ming);
printf("ID:");
puts(st->hao);
printf("Score:");
for(int i=0;i<4;i++)
{
printf("%d ",st->score[i]);
}
printf("%d\n",st->score[4]);
printf("average:%.2lf ",(double)st->total/5);
printf("total:%d",st->total);
return 0;
}
void pai(int m[],int size)
{
int temp;
for(int i=0;i<size-1;i++)
{
for(int count=0;count<size-i;count++)
{
if(m[count]<m[count+1])
{
temp=m[count+1];
m[count+1]=m[count];
m[count]=temp;
}
}
}
}
学生的属性包括姓名、学号、5门课程的成绩、平均成绩与总成绩。已知一个学生的姓名、学号与5门课程的成绩,你的任务是计算该学生的平均成绩与总成绩,并将该学生的5门课程成绩按照从高到底进行排序,最后将这个同学的完整信息输出。学生的姓名中只能包含大小写字母与空格字符,不会超过20个字符;学生的学号是个长度不会超过20的字符串,只包含数字字符;课程成绩均为0—100的整数。
要求:
1.在本题中,你要设计一个结构来存储学生的信息。在此结构中,需要有一个字符数组来存储姓名;一个字符数组来存储学号;一个长度为5的整型数组来存储5门课程的成绩;一个双精度浮点型变量存储平均成绩,一个整型变量存储总成绩。
2.在对结构变量的成员进行赋值与排序的时候,你要使用“结构变量名+‘.’+结构成员名”这种方式访问变量,如“student.score”;而在输出学生信息时,你要用一个结构指针指向该结构,然后用结构指针访问结构中的变量,即“结构指针名+‘->’+结构成员名”,如“ptr->score”。
输入格式:
学生信息的输入按照姓名、学号、5门课程成绩的顺序输入,共占三行,具体格式见样例。
输出格式:
姓名占一行;学号占一行;5门成绩中间用空格分开,最后一个成绩后是换行符,从高到底进行排序,占一行;平均成绩与总成绩用空格分隔,占一行,平均成绩保留两位小数。
输入样例:
Liu Mengmeng
0821131666666
88 90 93 91 85
输出样例:
Name:Liu Mengmeng
ID:0821131666666
Score:93 91 90 88 85
average:89.40 total:447