访问成员
输出平均分最高的学生信息
输入:整数n(1<=n<=10),在下面n行输入n个学生的信息,包括学号、姓名、三门课程成绩(整数)。
输出:在一行中输出平均分最高的学生信息:学号、姓名、平均分(保留两位小数)。(如果平均分最高的学生有多个,按输入顺序输出第一个学生的信息。)
输入样例:
3
101 Zhang 78 87 85
102 Wang 91 88 90
103 Li 75 90 84
输出样例:
num:102,name:Wang,average:89.67
注意:
- 平均分也放在结构体里
- 输入、输出、计算平均值、比较大小等都可以另外封装在函数里(如下例)
- scanf的%s以空格或换行作为结束标志
- 同类型结构题可以直接赋值,如max=stud;
解答:
#include <stdio.h>
#define N 20
typedef struct stu{
int id;
char name[N];
int score[3];
double aver;
} stu;
int main()
{
int n;
stu stud, max;
scanf("%d", &n);
scanf("%d %s %d %d %d", &stud.id, stud.name, &stud.score[0], &stud.score[1], &stud.score[2]);
stud.aver = (stud.score[0] + stud.score[1] + stud.score[2]) / 3.0; //注意,int转成double
max = stud; //同类型结构可以直接赋值
for ( int i=2; i<=n; i++ ){
scanf("%d %s %d %d %d", &stud.id, stud.name, &stud.score[0], &stud.score[1], &stud.score[2]);
stud.aver = (stud.score[0] + stud.score[1] + stud.score[2]) / 3.0; //注意,int转成double
if ( stud.aver>max.aver ) //相等的就不输出了
max = stud;
}
printf("num:%d,name:%s,average:%.2f", max.id, max.name, max.aver);
return 0;
}
结构类型数组
学生成绩排序
输入:一个正整数n(n<50),下面n行输入n个学生的信息,包括:学号、姓名、三门课程成绩(整数)。
输出:输出从高到低排序后的学生信息,包括:学号、姓名、平均分(保留两位小数)。如果平均分相同,按输入的先后顺序排列。
分析:
- 输入n个学生信息——函数input,需要数组stud[]和学生个数n
- 从高到低排序,且如果平均分相同,按输入的先后顺序排列(选择排序法)——函数max_min,需要数组stud[]和学生个数n
- 在函数max_min排序时,需要不断将剩余数中的最大值换到前面——函数swap,需要两个stu型指针,分别指向两个需要交换位置的数组stud[]
- 输出排序后的n个学生信息——函数output,需要数组stud[]和学生个数n
#include <stdio.h>
#define NAME 20
#define STU_N 50
typedef struct student{
int num; //学号
char name[NAME]; //姓名
int score[3]; //三科成绩
double aver; //平均分
} stu; //命名为stu
void input(stu stud[], int n);
void max_min(stu stud[], int n);
void swap(stu *a, stu *b);
void output(stu stud[], int n);
int main()
{
int n; //学生人数<50
stu stud[STU_N]; //结构类型数组
scanf("%d", &n);
//输入学生信息并记录平均分
input(stud,n);
//选择法排序
max_min(stud,n);
//顺序输出
output(stud,n);
return 0;
}
//输入学生信息并记录平均分
void input(stu stud[], int n)
{
int i;
for ( i=0; i<n; i++ ){
scanf("%d %s %d %d %d", &stud[i].num, stud[i].name, &stud[i].score[0], &stud[i].score[1], &stud[i].score[2]);
stud[i].aver = (stud[i].score[0] + stud[i].score[1] + stud[i].score[2]) / 3.0; //注意类型转换
}
}
//选择法排序
void max_min(stu stud[], int n)
{
int index = 0;
for ( int i=0; i<n-1; i++ ){
index = i;
for ( int j=i+1; j<n; j++ ){
if ( stud[j].aver>stud[index].aver ){
index = j;
}
}
swap(&stud[index],&stud[i]);
}
}
//交换位置
void swap(stu *a, stu *b)
{
stu tmp = *a;
*a = *b;
*b = tmp;
}
//顺序输出
void output(stu stud[], int n)
{
for ( int i=0; i<n; i++ ){
printf("%d,%s,%.2f\n", stud[i].num, stud[i].name, stud[i].aver);
}
}
修改学生成绩
输入:一个学生的学号、课程以及成绩,在自定义函数update_score()中修改该学生指定课程的成绩
函数接口定义:
int update_score(struct student *p, int n, int num, int course, int score);
其中p是结构指针,n是学生个数,num是学生学号,course是课程序号(1,2,3),score是修改后的课程成绩。函数须返回指定学生的顺序位置,如果查无此人,返回-1。
学生信息结构体如下:
struct student{ /*学生信息结构定义*/
int num; /* 学号 */
char name[10]; /* 姓名 */
int math, english, computer; /* 三门课程成绩 */
};
分析:修改学生成绩,需要改变结构体成员变量的值,故函数参数为结构类型指针
解答:
int update_score(struct student *p, int n, int num, int course, int score)
{
int pos = -1; //默认为查无此人
for ( int i=0; i<n; i++ ){
if ( num==p[i].num ){
pos = i;
break;
}
}
if ( course==1 ) p[pos].math = score;
else if ( course==2 ) p[pos].english = score;
else p[pos].computer = score;
return pos;
}