|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- void update() {
- char name[100]; // 姓名字符串
- printf("请输入要修改信息的学生姓名:\n");
- scanf("%s", name);
- Employee *current = head; // 当前节点指针
- // 遍历链表,查找匹配姓名的学生节点
- while (current != NULL) {
- if (strcmp(current->name, name) == 0) {
- printf("请输入新的工号:\n");
- scanf("%d", &(current->id));
- printf("请输入新的密码:\n");
- scanf("%s", current->password);
- printf("请输入修改的名字:\n");
- scanf("%d", &(current->name));
- printf("请输入修改的工资:\n");
- scanf("%f", &(current->salary));
- printf("修改成功!\n");
- return; // 修改成功后直接返回
- }
- current = current->next;
- }
-
- printf("未找到该学生信息!\n");
- }
复制代码
在你的代码中,你使用了一个字符变量 `char name` 来存储学生姓名字符串,这是一个错误。正确的做法应该是使用一个字符数组来存储字符串。
此外,在 `scanf` 函数调用中,你使用了 `%s` 格式说明符来读取字符串,但是却没有提供正确的参数。正确的做法是将 `name` 修改为一个字符数组,并在 `scanf` 函数中使用 `%s` 来读取字符串,同时提供正确的参数 `&name` 来获取该字符串。
下面是修复后的代码:
- void update() {
- char name[50]; // 姓名字符串
- printf("请输入要修改信息的学生姓名:\n");
- scanf("%s", name);
- Employee *current = head; // 当前节点指针
- // 遍历链表,查找匹配姓名的学生节点
- while (current != NULL) {
- if (strcmp(current->name, name) == 0) {
- printf("请输入新的工号:\n");
- scanf("%d", &(current->id));
- printf("请输入新的密码:\n");
- scanf("%s", current->password);
- printf("请输入修改的名字:\n");
- scanf("%s", current->name);
- printf("请输入修改的工资:\n");
- scanf("%f", &(current->salary));
- printf("修改成功!\n");
- return; // 修改成功后直接返回
- }
- current = current->next;
- }
-
- printf("未找到该学生信息!\n");
- }
复制代码
请注意,上述修复只是解决了你提到的bug,如果还有其他问题,请提供更多细节描述。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
|
|