《C语言程序设计(第3版)》教材配套习题 第九章

访问成员

输出平均分最高的学生信息

输入:整数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

注意

  1. 平均分也放在结构体里
  2. 输入、输出、计算平均值、比较大小等都可以另外封装在函数里(如下例)
  3. scanf的%s以空格或换行作为结束标志
  4. 同类型结构题可以直接赋值,如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个学生的信息,包括:学号、姓名、三门课程成绩(整数)。
输出:输出从高到低排序后的学生信息,包括:学号、姓名、平均分(保留两位小数)。如果平均分相同,按输入的先后顺序排列。
分析

  1. 输入n个学生信息——函数input,需要数组stud[]和学生个数n
  2. 从高到低排序,且如果平均分相同,按输入的先后顺序排列(选择排序法)——函数max_min,需要数组stud[]和学生个数n
  3. 在函数max_min排序时,需要不断将剩余数中的最大值换到前面——函数swap,需要两个stu型指针,分别指向两个需要交换位置的数组stud[]
  4. 输出排序后的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;
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值