实现一个通讯录;
通讯录可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址
提供方法:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
通讯录可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址
提供方法:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
7. 以名字排序所有联系人
(1)头文件contact.h
#ifndef __CONTACT #define __CONTACT #endif//条件编译 #pragma warning (disable:4996) #include<stdio.h> #include<stdlib.h> #include<string.h> #include<assert.h> #define N 1000 struct contact { char name[30]; char gender[10]; int age; int telephone; char address[100]; }; void menu(); void show(struct contact *p, int len); void Add_linkman(struct contact *p, int len, int flag); void Delete_linkman(struct contact *p, int d_number, int len); void Find_member(struct contact *p, int d_number, int len); void empty(struct contact *p); void Modify(struct contact *p, int M_member); void cmp(const void *a, const void *b); void sort(struct contact *p, int len);
(2)函数具体实现contact.c
#include"test.h" void menu() { printf("##################################\n"); printf("##### 1.增加联系人信息 #####\n"); printf("##### 2.删除联系人信息 #####\n"); printf("##### 3.查找指定联系人信息 #####\n"); printf("##### 4.修改指定联系人信息 #####\n"); printf("##### 5.显示所有联系人信息 #####\n"); printf("##### 6.清空所有联系人 #####\n"); printf("##### 7.以名字排序所有联系人 #####\n"); printf("##### 0.退出! #####\n"); printf("##################################\n"); } void show(struct contact *p, int len) { assert(p); int i = 0; for (i = 0; i < len; i++) { printf("name:%s gender:%s age:%d telephone:%d address:%s", \ p[i].name, p[i].gender, p[i].age, p[i].telephone, p[i].address); printf("\n"); } } void Add_linkman(struct contact *p, int len, int flag) { assert(p); int i = 0; for (i = flag; i < len; i++) { printf("请输入姓名:"); scanf("%s", &p[i].name); printf("请输入姓别:"); scanf("%s", &p[i].gender); printf("请输入年龄:"); scanf("%d", &p[i].age); printf("请输入电话:"); scanf("%d", &p[i].telephone); printf("请输入地址:"); scanf("%s", &p[i].address); } } void Delete_linkman(struct contact *p, int d_number, int len) { assert(p); int i = 0; for (i = d_number - 1; i < len - 1; i++) { p[i] = p[i + 1]; } } void Find_member(struct contact *p, int d_number, int len) { assert(p); if (d_number - 1 >= 0 || d_number - 1<len) { printf("name:%s gender:%s age:%d telephone:%d address:%s", \ p[d_number].name, p[d_number].gender, p[d_number].age, p[d_number].telephone, p[d_number].address); printf("\n"); } else { printf("不存在该联系人:"); return; } } void empty(struct contact *p) { assert(p); int i = 0; for (i = 0; i <1000; i++) { memset(p + i, 0, sizeof(struct contact)); } } void Modify(struct contact *p, int M_member) { assert(p); printf("修改之前联系人的信息为:"); printf("\n"); printf("name:%s gender:%s age:%d telephone:%d address:%s", \ p[M_member - 1].name, p[M_member - 1].gender, p[M_member - 1].age, p[M_member - 1].telephone, p[M_member - 1].address); printf("\n"); printf("请输入要修改的信息:"); printf("请输入姓名:"); scanf("%s", &p[M_member - 1].name); printf("请输入姓别:"); scanf("%s", &p[M_member - 1].gender); printf("请输入年龄:"); scanf("%d", &p[M_member - 1].age); printf("请输入电话:"); scanf("%d", &p[M_member - 1].telephone); printf("请输入地址:"); scanf("%s", &p[M_member - 1].address); } void cmp(const void *a, const void *b) { struct contact *aa = (struct contact *)a; struct contact *bb = (struct contact *)b; if (aa->name != bb->name) return(strcmp((aa->name), (bb->name))); } void sort(struct contact *p, int len) { assert(p); qsort(p, len, sizeof(struct contact), cmp); }
(3)main函数
#include"test.h" int main() { int num = 0; struct contact student[N]; int len = 0; int flag = 0;//定义一个标志位来标志结构体数组中每个结构体的位置 int total = N; int delete_number = 0; menu(); while (1) { printf("请输入数字进行选择:"); scanf("%d", &num); switch (num){ case 1:{ printf("请添加len个学生的信息:"); scanf("%d", &len); Add_linkman(student, len + flag, flag); flag = flag + len; }break; case 2:{ printf("请输入要删除的第i个学生的信息:"); scanf("%d", &delete_number); Delete_linkman(student, delete_number, len + flag); flag = flag - 1; }break; case 3:{ int Find_number = 0; printf("请输入要查找的第i个学生的信息:"); scanf("%d", &Find_number); Find_member(student, delete_number, len + flag); }break; case 4:{ printf("请输入要修改的的第i个学生的信息:"); int M_member = 0; scanf("%d", &M_member); Modify(student, M_member); }break; case 5:{ printf("打印所有联系人的信息:\n"); show(student, flag); }break; case 6:{ printf("清空所有联系人:"); empty(student); }break; case 7:{ printf("根据名字排序所有联系人:\n"); sort(student, len + flag); }break; case 0:{ exit(1); } default:printf("enter error data!!"); } } system("pause"); return 0; }