//修改员工信息函数 int change(Node *worker) { Node *p; char find[20]; p = worker->next; if (p == NULL) { printf("\n提示:没有资料可以修改!\n"); return 0; } printf("请输入要修改的员工号"); scanf("%s", find); while (p != NULL) { if (strcmp(p->data.jobNo, find) == 0) { break; } p = p->next; } if (p!=NULL) { int x; while (1) { printf("完成修改请输入0,否则输入非0数字进行修改!"); scanf("%d", &x); if (x == 0) { break; } printf(" 请输入新员工号: "); scanf("%s", p->data.jobNo); printf(" 请输入新员工姓名: "); scanf("%s", p->data.name); printf(" 请输入新员工性别: "); scanf("%s", p->data.sex); printf(" 请输入新员工出生年月: "); scanf("%s", p->data.birthday); printf(" 请输入新员工职务: "); scanf("%s", p->data.position); printf(" 请输入新员工工资: "); scanf("%s", p->data.salary); printf(" \n提示:该职工资料已经修改!\n "); } } else printf("\n提示:没有你要修改的资料!\n "); }
时间: 2024-01-10 09:02:57 浏览: 74
这段代码是一个修改员工信息的函数,它首先检查链表中是否有员工信息,如果没有则提示没有资料可以修改,如果有,则要求输入要修改的员工号。然后遍历链表,查找该员工号对应的节点,如果找到了,则进入一个循环,要求输入要修改的信息,直到输入0为止,输入的非0数字将被认为是要修改的信息。如果输入的0,则退出循环,提示该职工资料已经修改。如果没有找到对应的员工号,则提示没有你要修改的资料。
相关问题
void Linklist::update(worker* data) //更新节点信息 { worker* p = head; worker* ptr; while (p->next != NULL) { if (p->next->m_name == data->m_name) { ptr = p->next; if (p->next->next == NULL) { p->next = data; } else { data->next = p->next->next; p->next = data; } delete ptr; break; } else { p = p->next; } } }
这是一个关于链表的程序代码,用于更新节点信息。我可以回答这个问题。这段代码的作用是:遍历链表,找到与传入的节点信息相同的节点,然后将该节点替换为传入的节点信息。如果该节点是链表的最后一个节点,则直接将传入的节点信息添加到链表的末尾。如果不是最后一个节点,则将传入的节点信息插入到该节点的后面,然后删除原来的节点。
int Linklist::delete_name(string name) //按值删除 { worker* p = head; int count = 0; while (p->next != NULL) { if (p->next->m_name == name) { worker* ptr = p->next; p->next = ptr->next; free(ptr); count++; } else { p = p->next; } } if (count == 0) { cout << "未发现该名员工!" << endl; return -1; } }解释这段代码的原理
这段代码是一个链表中按照员工姓名删除节点的函数。它首先定义了一个指向链表头节点的指针p,然后通过循环遍历链表,查找与给定姓名相同的节点。如果找到了这样的节点,它会用一个指针ptr指向该节点,然后将该节点从链表中删除,并释放该节点的内存空间。最后,它会返回删除的节点数。如果没有找到与给定姓名相同的节点,它会输出一条提示信息并返回-1。
阅读全文
相关推荐














