单位员工通讯录管理系统
为某个单位建立一个员工通讯录管理系统,可以方便查询每一个员工的手机号、及电子邮箱。其功能包括通讯录链表的建立、员工通讯信息的查询、修改、插入与删除、以及整个通讯录表的输出。
操作分为查询(query)、修改(modify)、添加(add)、删除(del)、打印(print)
1. 查询:输入员工姓名,输出员工信息,若员工不存在,输出“NOT FOUND!”
2. 修改:输入员工姓名、要修改的属性、修改信息。姓名为name、电话为tel、邮箱为email。
3. 添加:输入员工编号、姓名、电话号码、邮箱。
4. 删除:输入员工姓名,将其从通讯录中删除。
5. 打印:输出通讯录 。
第一:包含需要的头文件
#include<iostream>
#include<string.h>
using namespace std;
int n;//定义一个全局变量n作为员工数目
第二:用链表作为存储方式:
typedef struct Staff {
int num;
char name[20];
char tel[20];
char email[20];
Staff *next;
}Staff,* Sta;
第三:定义查找方法:
1. 查询:输入员工姓名,输出员工信息,若员工不存在,输出“NOT FOUND!”
//1. 查询:输入员工姓名,输出员工信息,若员工不存在,输出“NOT FOUND!”
void Query(Sta &s) {
char name[20];
cin >> name;
Staff *sta = new Staff;
sta = s->next;
while (sta)
{
if (strcmp(sta->name, name) == 0) {
cout << sta->num << ' ' << sta->name << ' ' << sta->tel << ' ' << sta->email << endl;
return;
}
sta = sta->next;
}
cout << "NOT FOUND!" << endl;
}
第四:定义修改数据的方法
2. 修改:输入员工姓名、要修改的属性、修改信息。姓名为name、电话为tel、邮箱为email。
//2. 修改:输入员工姓名、要修改的属性、修改信息。姓名为name、电话为tel、邮箱为email。
void Modify(Sta &s) {
Staff *sta = new Staff;
char name[20],type[20];
char change[20];
sta = s->next;
cin >> name;
while (sta)
{
if (strcmp(sta->name, name) == 0) {
cin >> type;
if (strcmp(type, "name") == 0) {
cin >> change;
strcpy(sta->name, change);
return;
}
else if (strcmp(type, "tel") == 0) {
cin >> change;
strcpy(sta->tel, change);
return;
}
else {
cin >> change;
strcpy(sta->email, change);
return;
}
}
sta = sta->next;
}
}
第五:定义添加员工的方法
3. 添加:输入员工编号、姓名、电话号码、邮箱。
// 3. 添加:输入员工编号、姓名、电话号码、邮箱。
void Add(Sta &s) {
Staff *r = new Staff;
r = s;
while (r->next)
{
r = r->next;
}
Staff *sta = new Staff;
sta->next = NULL;
cin >> sta->num;
cin >> sta->name;
cin >> sta->tel;
cin >> sta->email;
r->next = sta;
}
第六:定义删除员工的方法
4. 删除:输入员工姓名,将其从通讯录中删除。
//4. 删除:输入员工姓名,将其从通讯录中删除。
void Del(Sta &s) {
char name[20];
Staff *p = new Staff;
Staff *q = new Staff;
p = s;
cin >> name;
while (p)
{
if (strcmp(name, p->next->name) == 0) {
q = p->next;
p->next = q->next;
delete q;
return;
}
p = p->next;
}
}
第七:打印通讯录
5. 打印:输出通讯录 。
//5. 打印:输出通讯录 。
void PrintStaff(Sta &s) {
Staff *p = new Staff;
p = s->next;
while (p)
{
cout << p->num << ' ' << p->name << ' ' << p->tel << ' ' << p->email << endl;
p = p->next;
}
}
第八:定义main方法执行
int main() {
Staff *S = new Staff;
Staff *r = new Staff;
r = S;
char q[20];
S->next = NULL;
cin >> n;
for (int i = 0; i < n; i++) {
Staff *p = new Staff;
cin >> p->num;
cin >> p->name;
cin >> p->tel;
cin >> p->email;
p->next = NULL;
r->next = p;
r = p;
}
int sum;
cin >> sum;
for (int i = 0; i < sum; i++) {
cin>>q;
if (strcmp(q, "query") == 0) {
Query(S);
}
else if (strcmp(q, "modify")==0)
Modify(S);
else if (strcmp(q, "add")==0)
Add(S);
else if (strcmp(q, "del")==0)
Del(S);
else
PrintStaff(S);
}
return 0;
}