void change() { printf("\n请输入学生的学号:"); int p,o,m; scanf("%d",&o); for(p=0;p<STUDENT_NUM;p++) { if(o==student[p].no) { printf("\n学号 姓名 年龄 性别 班级 宿舍 电话号码\n"); printf("%-4d%-4s%-4d%-3s%-4d%-5s%s",student[p].no,student[p].name,student[p].age,student[p].sex,student[p].c1ass,student[p].address,student[p].phone); break; } } printf("\n是否修改\n1.是 2.否\n"); scanf("%d",&m); if(m=1) { p1:printf("\n请输入姓名:\n"); getchar(); scanf("%s",&student[p].name); printf("请输入年龄:\n"); getchar(); scanf("%d",&student[p].age); printf("请输入性别:\n"); scanf("%s",&student[p].sex); printf("请输入班级:\n"); getchar(); scanf("%d",&student[p].c1ass); printf("请输入宿舍:\n"); getchar(); scanf("%s",&student[p].address); printf("请输入电话:\n"); getchar(); scanf("%s",&student[p].phone); printf("\n学号 姓名 年龄 性别 班级 宿舍 电话号码\n"); printf("%-4d%-4s%-4d%-3s%-4d%-5s%s",student[p].no,student[p].name,student[p].age,student[p].sex,student[p].c1ass,student[p].address,student[p].phone); printf("\n1.重新修改 2.结束"); getchar(); scanf("%d",&m); if(m=1) { goto p1; } else if(m=2) { printf("\n返回菜单\n"); } } else if(m=2) { printf("\n返回菜单\n"); } }有什么问题
时间: 2024-04-05 15:31:46 浏览: 19
这段代码存在以下问题:
1. 第一行应该加上函数返回类型,如`void`。
2. 在第一次输入学号后,没有对输入的学号进行判断,如果输入的学号不存在,则会继续执行,导致出现错误或者异常。
3. 在第二次输入m的时候,应该使用`==`进行判断,而不是`=`,因为`=`是赋值操作符,而`==`才是判断是否相等的操作符。
4. 在第二次输入m的时候,没有对输入的m进行判断,即使输入的不是1或2,也会继续执行,导致程序异常。
5. scanf函数中使用`%s`时,应该不加`&`,因为`%s`已经表示了字符串的地址。而对于`%d`,则需要加上`&`,表示取地址。
6. 当用户选择重新修改时,应该重新输入学生的信息,并且只有当用户确认信息无误时,才退出循环,而不是在输入信息时就要求用户选择是重新修改还是退出。
7. 在输出学生信息时,缺少换行符,导致输出格式不清晰。
相关问题
void zengjia(struct student *head) { int flag, i = 1; char change = '\0'; //system("cls"); do { struct student *temp= (student*) malloc(sizeof(student)); struct student *p1; flag = 0; printf("添加的第%d个学生:\n", i); printf("学号:"); scanf("%s", temp->num); p1 = head->next; student *q1 = head; while (p1) { if (strcmp(p1->num, temp->num) == 0) { printf("学号已存在。\n"); flag++; return; } p1 = p1->next; q1 = q1->next; } if (flag == 0) { printf("\n输入正确,请继续:\n"); printf("\n姓名:"); scanf("%s", temp->name); printf("\n金额:"); scanf("%lf", &temp->money); printf(" 此学生信息已添加成功!\n"); temp->next = NULL; q1->next = temp; i++; } printf("---是否继续添加下一个学生信息---\n"); printf(" Y/N \n"); do { change = getchar(); } while (change != 'y' && change != 'Y' && change != 'n' && change != 'N'); } while (change == 'Y' || change == 'y'); }
好的,以下是您提供的代码的注释:
```
void zengjia(struct student *head) {
int flag, i = 1; // 定义标记变量flag和计数变量i
char change = '\0'; // 定义字符变量change,初值为'\0'
//system("cls"); // 清屏(注释掉了)
// 循环添加学生信息
do {
struct student *temp= (student*) malloc(sizeof(student)); // 动态分配内存
struct student *p1;
flag = 0; // 标记变量flag初值设为0
printf("添加的第%d个学生:\n", i);
printf("学号:");
scanf("%s", temp->num);
p1 = head->next; // p1指向链表第一个节点
student *q1 = head; // q1指向head
while (p1) { // 遍历链表
if (strcmp(p1->num, temp->num) == 0) { // 如果学号已存在
printf("学号已存在。\n");
flag++; // 标记变量flag加1
return; // 直接返回
}
p1 = p1->next; // 指针p1指向下一个节点
q1 = q1->next; // 指针q1指向p1的前一个节点
}
if (flag == 0) { // 如果学号不存在
printf("\n输入正确,请继续:\n");
printf("\n姓名:");
scanf("%s", temp->name);
printf("\n金额:");
scanf("%lf", &temp->money);
printf(" 此学生信息已添加成功!\n");
temp->next = NULL;
q1->next = temp; // 将新节点添加到链表尾部
i++; // 计数器加1
}
// 是否继续添加下一个学生信息
printf("---是否继续添加下一个学生信息---\n");
printf(" Y/N \n");
do {
change = getchar();
} while (change != 'y' && change != 'Y' && change != 'n' && change != 'N');
} while (change == 'Y' || change == 'y'); // 如果输入为Y或y,则继续添加
}
```
希望这些注释能帮助您理解这段代码的功能和实现方式。
void zengjia(struct student *head) { int flag, i = 1; char change = '\0'; //system("cls"); do {//循环添加学生信息 struct student *temp= (student*) malloc(sizeof(student));// 动态分配内存 struct student *p1; flag = 0; printf("添加的第%d个学生:\n", i); printf("学号:"); scanf("%s", temp->num); p1 = head->next;// p1指向链表第一个节点 student *q1 = head; // q1指向head while (p1) {// 遍历链表 if (strcmp(p1->num, temp->num) == 0) { printf("学号已存在。\n"); flag++; return; } p1 = p1->next;// 指针p1指向下一个节点 q1 = q1->next; // 指针q1指向p1的前一个节点 } if (flag == 0) { printf("\n输入正确,请继续:\n"); printf("\n姓名:"); scanf("%s", temp->name); printf("\n金额:"); scanf("%lf", &temp->money); printf(" 此学生信息已添加成功!\n"); temp->next = NULL;// 将新节点添加到链表尾部 q1->next = temp; i++; } printf("---是否继续添加下一个学生信息---\n"); printf(" Y/N \n"); do { change = getchar(); } while (change != 'y' && change != 'Y' && change != 'n' && change != 'N'); } while (change == 'Y' || change == 'y'); }
这段代码是一个添加学生信息的函数,具体解释如下:
1. `void zengjia(struct student *head)`: 函数名为 `zengjia`,返回值为 `void`,接收一个 `struct student` 类型的指针参数 `head`。
2. `int flag, i = 1; char change = '\0';`: 声明了三个变量,分别为 `flag`,`i` 和 `change`,分别用于标记添加是否成功、记录添加学生的数量和记录是否继续添加学生信息。
3. `do {//循环添加学生信息`: 使用 `do...while` 循环来不断添加学生信息,直到用户不再需要添加。
4. `struct student *temp= (student*) malloc(sizeof(student));// 动态分配内存`: 动态分配了一个 `struct student` 类型的内存空间,用于存储新添加的学生信息。
5. `struct student *p1;` 和 `student *q1 = head;`: 声明了两个 `struct student` 类型的指针变量 `p1` 和 `q1`,分别用于遍历链表和记录当前节点的前一个节点。
6. `p1 = head->next;`:将指针 `p1` 指向链表的第一个节点。
7. `while (p1) {// 遍历链表`: 使用 `while` 循环来遍历链表中的每个节点。
8. `if (strcmp(p1->num, temp->num) == 0) { ... }`: 如果新添加的学生信息中的学号已经存在于链表中,就会提示学号已存在,标记 `flag` 加一,然后直接返回函数。
9. `p1 = p1->next;` 和 `q1 = q1->next;`: 将指针 `p1` 和 `q1` 分别指向链表的下一个节点和当前节点的下一个节点,用于继续遍历链表。
10. `if (flag == 0) { ... }`: 如果新添加的学生信息中的学号不存在于链表中,就会提示输入正确,然后要求输入学生姓名和金额,最后将新节点添加到链表尾部。
11. `printf("---是否继续添加下一个学生信息---\n"); ... } while (change == 'Y' || change == 'y');`: 在每轮循环结束后,询问用户是否需要继续添加学生信息。如果用户输入了 `Y` 或 `y`,就继续添加;否则,函数执行结束。
总体来说,这段代码的功能是动态添加学生信息到链表中,如果新添加的学生信息中的学号已经存在于链表中,则提示学号已存在,否则将新节点添加到链表尾部。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)