输入n(n<50)个学生的成绩信息,再输入一个学生的学号、课程以及成绩,在自定义函数update_score()中修改该学生指定课程的成绩。 函数接口定义: int update_score(struct student *p, int n, int num, int course, int score); 其中p是结构指针,n是学生个数,course是课程序号,score是修改后的课程成绩。函数须返回指定学生的顺序位置,如果查无此人,返回-1。 裁判测试程序样例: #include <stdio.h> 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 main(void) { int i, pos, n, num, course, score; struct student students[50]; /* 定义结构数组 */ scanf("%d", &n); for(i = 0; i < n; i++){ scanf("%d", &students[i].num); scanf("%s", students[i].name); scanf("%d", &students[i].math); scanf("%d", &students[i].english); scanf("%d", &students[i].computer); } /* 输入待修改学生信息 */ scanf("%d", &num); scanf("%d", &course); scanf("%d", &score); /*调用函数,修改学生成绩*/ pos = update_score(students, n, num, course, score); /*输出修改后的学生信息*/ if(pos == -1) printf("Not found!\n"); else { printf("%d,%d,%d,%d\n", students[pos].num, students[pos].math, students[pos].english, students[pos].computer); } return 0; } /* 请在这里填写答案 */ 输入样例: 3 101 Zhang 78 87 85 102 Wang 91 88 90 103 Li 75 90 84 102 2 89 输出样例: 在这里给出相应的输出。例如: 102,91,89,90
时间: 2024-03-17 19:47:39 浏览: 165
这道题目需要实现一个函数update_score()来更新指定学生的指定课程成绩。函数接收五个参数,分别是结构体指针p、学生个数n、学生学号num、课程序号course和修改后的课程成绩score。函数需要返回指定学生的顺序位置,如果查无此人,返回-1。
首先需要遍历整个结构体数组,查找给定学号的学生是否存在。如果存在,则根据课程序号修改对应的成绩。如果不存在,则返回-1。
下面是具体的代码实现:
```c
int update_score(struct student *p, int n, int num, int course, int score) {
int i;
for (i = 0; i < n; i++) {
if (p[i].num == num) { // 找到指定学号的学生
if (course == 1) {
p[i].math = score; // 修改数学成绩
} else if (course == 2) {
p[i].english = score; // 修改英语成绩
} else if (course == 3) {
p[i].computer = score; // 修改计算机成绩
}
return i; // 返回该学生的顺序位置
}
}
return -1; // 查无此人,返回-1
}
```
在函数体内,使用for循环遍历整个结构体数组,逐个比较学生的学号是否等于给定学号num。如果相等,根据课程序号course修改对应的成绩,然后返回该学生的顺序位置i。如果遍历完整个数组都没有找到给定学号的学生,则返回-1。
注意,因为返回的是整型变量,所以在函数调用时需要使用整型变量来接收函数返回值。例如,可以定义一个整型变量pos,然后将函数返回值赋给它,如下所示:
```c
pos = update_score(students, n, num, course, score);
```
最后,根据pos是否为-1来判断查找是否成功,并输出相应的结果即可。
阅读全文