修改成绩函数 void modify_grade() { char id[20]; printf("请输入要修改成绩的学生学号:"); scanf("%s", id); for (int i = 0; i < student_count; i++) { if (strcmp(id, students[i].id) == 0) { // 找到目标学生 printf("原成绩:%d,请输入新成绩:", students[i].grade); scanf("%d", &students[i].grade); printf("修改成功\n"); return; } } printf("找不到该学生,请重新输入\n"); }用了什么语句 解释代码
时间: 2024-04-26 19:25:35 浏览: 8
这是一个名为 modify_grade 的函数,它的作用是修改指定学生的成绩。函数中用到了以下语句:
- char id[20];:定义了一个字符数组 id,用于存储用户输入的学生学号。
- printf("请输入要修改成绩的学生学号:");:向用户输出提示信息,要求用户输入目标学生的学号。
- scanf("%s", id);:使用 scanf 函数读取用户输入的学号,并存储到 id 数组中。
- for (int i = 0; i < student_count; i++) { ... }:使用 for 循环遍历学生数组,查找与输入的学号相对应的学生。
- if (strcmp(id, students[i].id) == 0) { ... }:使用 strcmp 函数比较输入的学号和当前遍历到的学生的学号是否相等,如果相等则说明找到了目标学生。
- printf("原成绩:%d,请输入新成绩:", students[i].grade);:输出目标学生的原成绩,并提示用户输入新成绩。
- scanf("%d", &students[i].grade);:使用 scanf 函数读取用户输入的新成绩,并将其存储到目标学生的成绩属性中。
- printf("修改成功\n");:输出提示信息,说明修改操作成功。
- return;:退出函数,结束修改操作。
- printf("找不到该学生,请重新输入\n");:如果循环结束后仍然没有找到目标学生,则输出提示信息,告知用户输入的学号有误。
相关问题
用数据结构实现学生成绩管理系统,并提供代码
好的,下面是使用数据结构实现学生成绩管理系统的代码:
```
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义学生结构体
typedef struct student {
char name[20]; // 学生姓名
int id; // 学生学号
float grade; // 学生成绩
struct student* next; // 指向下一个学生的指针
} Student;
// 定义全局变量,指向链表头结点和尾结点
Student* head = NULL;
Student* tail = NULL;
// 函数声明
void add_student();
void find_student();
void delete_student();
void modify_grade();
void show_all_students();
// 主函数
int main() {
int choice;
while (1) {
printf("请选择功能:\n");
printf("1. 添加学生\n");
printf("2. 查询学生\n");
printf("3. 删除学生\n");
printf("4. 修改成绩\n");
printf("5. 显示所有学生信息\n");
printf("6. 退出\n");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
find_student();
break;
case 3:
delete_student();
break;
case 4:
modify_grade();
break;
case 5:
show_all_students();
break;
case 6:
return 0;
default:
printf("请输入有效的选项!\n");
}
}
}
// 添加学生函数
void add_student() {
Student* new_student = (Student*) malloc(sizeof(Student)); // 动态分配内存
printf("请输入学生姓名:");
scanf("%s", new_student->name);
printf("请输入学生学号:");
scanf("%d", &new_student->id);
printf("请输入学生成绩:");
scanf("%f", &new_student->grade);
new_student->next = NULL;
if (head == NULL) { // 如果链表为空,新节点成为头结点和尾结点
head = new_student;
tail = new_student;
} else { // 否则将新节点插入到链表尾部
tail->next = new_student;
tail = new_student;
}
printf("添加成功!\n");
}
// 查询学生函数
void find_student() {
int id;
printf("请输入要查询的学生学号:");
scanf("%d", &id);
Student* p = head;
while (p != NULL) {
if (p->id == id) {
printf("姓名:%s 学号:%d 成绩:%.2f\n", p->name, p->id, p->grade);
return;
}
p = p->next;
}
printf("找不到该学生!\n");
}
// 删除学生函数
void delete_student() {
int id;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
Student* p = head;
Student* prev = NULL;
while (p != NULL) {
if (p->id == id) {
if (prev != NULL) { // 如果要删除的节点不是头结点
prev->next = p->next;
} else { // 如果要删除的节点是头结点
head = p->next;
}
free(p); // 释放内存
printf("删除成功!\n");
return;
}
prev = p;
p = p->next;
}
printf("找不到该学生!\n");
}
// 修改成绩函数
void modify_grade() {
int id;
printf("请输入要修改成绩的学生学号:");
scanf("%d", &id);
Student* p = head;
while (p != NULL) {
if (p->id == id) {
printf("请输入新的成绩:");
scanf("%f", &p->grade);
printf("修改成功!\n");
return;
}
p = p->next;
}
printf("找不到该学生!\n");
}
// 显示所有学生信息函数
void show_all_students() {
Student* p = head;
while (p != NULL) {
printf("姓名:%s 学号:%d 成绩:%.2f\n", p->name, p->id, p->grade);
p = p->next;
}
}
```
这里使用了链表数据结构来实现学生成绩管理系统,每个节点代表一个学生,包含学生姓名、学号、成绩以及指向下一个节点的指针。链表头结点和尾结点分别指向链表的第一个和最后一个节点。这样就可以方便地实现添加、删除、修改和查询学生,同时也支持动态扩展。
用c语言实现学生成绩管理系统
好的,学生成绩管理系统可以通过C语言实现。以下是一个简单的实现步骤:
1. 定义学生结构体
```
struct student {
char[20]; // 学生姓名
int id; // 学生学号
float grade; // 学生成绩
};
```
2. 定义学生数组和学生数量变量
```
struct student students[100]; // 最多100个学生
int num_students = 0; // 学生数量
```
3. 实现添加学生函数
```
void add_student() {
printf("请输入学生姓名:");
scanf("%s", students[num_students].name);
printf("请输入学生学号:");
scanf("%d", &students[num_students].id);
printf("请输入学生成绩:");
scanf("%f", &students[num_students].grade);
num_students++;
}
```
4. 实现查询学生函数
```
void find_student() {
int id;
printf("请输入要查询的学生学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
printf("姓名:%s 学号:%d 成绩:%.2f\n", students[i].name, students[i].id, students[i].grade);
return;
}
}
printf("找不到该学生!\n");
}
```
5. 实现删除学生函数
```
void delete_student() {
int id;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
for (int j = i; j < num_students - 1; j++) {
students[j] = students[j+1];
}
num_students--;
printf("删除成功!\n");
return;
}
}
printf("找不到该学生!\n");
}
```
6. 实现修改学生成绩函数
```
void modify_grade() {
int id;
printf("请输入要修改成绩的学生学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
printf("请输入新的成绩:");
scanf("%f", &students[i].grade);
printf("修改成功!\n");
return;
}
}
printf("找不到该学生!\n");
}
```
7. 实现显示所有学生信息函数
```
void show_all_students() {
for (int i = 0; i < num_students; i++) {
printf("姓名:%s 学号:%d 成绩:%.2f\n", students[i].name, students[i].id, students[i].grade);
}
}
```
8. 实现主函数,通过菜单选择功能
```
int main() {
int choice;
while (1) {
printf("请选择功能:\n");
printf("1. 添加学生\n");
printf("2. 查询学生\n");
printf("3. 删除学生\n");
printf("4. 修改成绩\n");
printf("5. 显示所有学生信息\n");
printf("6. 退出\n");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
find_student();
break;
case 3:
delete_student();
break;
case 4:
modify_grade();
break;
case 5:
show_all_students();
break;
case 6:
return 0;
default:
printf("请输入有效的选项!\n");
}
}
}
```
这样就可以实现一个简单的学生成绩管理系统了。当然,还有很多细节需要注意,比如输入错误处理、数组越界处理等等。