c语言链表厨师管理系统
时间: 2023-12-30 16:22:49 浏览: 32
以下是一个简单的C语言链表厨师管理系统的实现,其中包括添加、删除、查找和显示所有厨师信息的功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 厨师结构体
typedef struct chef {
int id; // 厨师编号
char name[20]; // 姓名
int age; // 年龄
char specialty[50]; // 特长
struct chef *next; // 指向下一个厨师的指针
} Chef;
// 全局变量,指向链表头
Chef *head = NULL;
// 添加厨师
void addChef() {
Chef *newChef = (Chef*)malloc(sizeof(Chef));
printf("请输入厨师编号:");
scanf("%d", &(newChef->id));
printf("请输入厨师姓名:");
scanf("%s", newChef->name);
printf("请输入厨师年龄:");
scanf("%d", &(newChef->age));
printf("请输入厨师特长:");
scanf("%s", newChef->specialty);
newChef->next = NULL;
if (head == NULL) {
head = newChef;
} else {
Chef *p = head;
while (p->next != NULL) {
p = p->next;
}
p->next = newChef;
}
printf("添加成功!\n");
}
// 删除厨师
void deleteChef() {
int id;
printf("请输入要删除的厨师编号:");
scanf("%d", &id);
if (head == NULL) {
printf("链表为空,删除失败!\n");
return;
}
Chef *p = head;
Chef *pre = NULL;
while (p != NULL) {
if (p->id == id) {
if (pre == NULL) {
head = p->next;
} else {
pre->next = p->next;
}
free(p);
printf("删除成功!\n");
return;
}
pre = p;
p = p->next;
}
printf("未找到该厨师,删除失败!\n");
}
// 查找厨师
void findChef() {
int id;
printf("请输入要查找的厨师编号:");
scanf("%d", &id);
if (head == NULL) {
printf("链表为空,查找失败!\n");
return;
}
Chef *p = head;
while (p != NULL) {
if (p->id == id) {
printf("编号:%d,姓名:%s,年龄:%d,特长:%s\n", p->id, p->name, p->age, p->specialty);
return;
}
p = p->next;
}
printf("未找到该厨师,查找失败!\n");
}
// 显示所有厨师信息
void showAllChefs() {
if (head == NULL) {
printf("链表为空,无法显示!\n");
return;
}
Chef *p = head;
while (p != NULL) {
printf("编号:%d,姓名:%s,年龄:%d,特长:%s\n", p->id, p->name, p->age, p->specialty);
p = p->next;
}
}
int main() {
int choice;
while (1) {
printf("请选择操作:\n");
printf("1.添加厨师\n");
printf("2.删除厨师\n");
printf("3.查找厨师\n");
printf("4.显示所有厨师信息\n");
printf("5.退出\n");
scanf("%d", &choice);
switch (choice) {
case 1:
addChef();
break;
case 2:
deleteChef();
break;
case 3:
findChef();
break;
case 4:
showAllChefs();
break;
case 5:
exit(0);
default:
printf("输入有误,请重新输入!\n");
break;
}
}
return 0;
}
```