实现一个通讯录;
通讯录可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址
实现功能:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
7. 以名字排序所有联系人
程序说明:
分模块实现
Phonelist.h 头文件――存放函数声明
fun.c ――函数实现
test.c――主函数
!Phonelist.h!
//Phonelist.h #pragma once #ifndef __ARROPT_H__ #define __ARROPT_H__ typedef struct PHONE { char Name[10]; int Age; char Sex[3]; //男/女 char Tele[13]; char Address[20]; //struct PHONE *next; }PHONE,*Phone; void ADD(PHONE *p);//添加 int DEL(Phone p, char*);//删除 void SEEK(Phone p, char *);//查找 void REVISE(Phone p, char *);//修改 void SHOW(Phone p);//显示 void FREE_ALL(Phone p);//清空 void SORT(Phone p, const size_t );//用快排排序必须将结构体第一个成员设为 Name,才可以实现 void menu(); #endif //__ARROPT_H__
fun.c ――函数实现
//fun.c #include<stdio.h> #include<stdlib.h> #include<string.h> #include"Phonelist.h" #define MAX 1000 //通讯录最大存储人数 //*****************添加************** void ADD(Phone p) { printf("请输入要录入联系人的姓名\n"); scanf_s("%s", p->Name, 10);//用scanf_s 函数实现字符串的输入 printf("请输入要录入联系人的性别(男/女)\n"); scanf_s("%s", p->Sex,3); printf("请输入要录入联系人的年龄\n"); scanf_s("%d", &p->Age); printf("请输入要录入联系人的电话\n"); scanf_s("%s",p->Tele, 13); printf("请输入要录入联系人的住址\n"); scanf_s("%s", p->Address, 20); } //****************删除************************** int DEL(Phone p,char *name) { int i = 0; int tmp = 0; Phone j = p; while (i++ < MAX) { if (strcmp(j->Name, name) == 0) { j->Age = 0; tmp = 1; break; } j++; } if (tmp == 1) { printf("%s信息删除成功!\n", name); return 1; } else { printf("%s信息删除失败,无此人!\n", name); return 0; } } //*********查找************* void show_one(Phone j) { printf("Name: %s ", j->Name); printf(" Age: %d ", j->Age); printf(" Tele: %s ", j->Tele); printf(" Sex: %s ", j->Sex); printf(" Address: %s \n", j->Address); } void SEEK(Phone p, char *name) { int i = 0; int tmp = 0; Phone j = p; while (i++ < MAX) { if (strcmp(j->Name, name) == 0) { tmp = 1; break; } j++; } if (tmp == 1) { printf("%s信息存在!\n", name); show_one(j); } else printf("%s信息查找失败,无此人!\n", name); } //***********修改********** void REVISE(Phone p, char *name) { int i = 0; int tmp = 0; Phone j = p; while (i++ < MAX) { if (strcmp(j->Name, name) == 0) { ADD(j); tmp = 1; break; } j++; } if (tmp == 1) printf("%s信息修改成功!\n", name); else printf("%s信息修改失败,无此人!\n", name); } //************显示所有联系人******** void SHOW(Phone p) { Phone j = p; int i = 0; int count = 0; while (i++ < MAX) { if (j->Age != 0) { show_one(j); count++; } j++; } if(0==count) printf("通讯录里还没有人,请选择1,添加您的好友\n"); } //************清空**************** void FREE_ALL(Phone p) { Phone j = p; int i = 0; while (i < MAX&&j->Age != 0) { j->Age = 0; j++; } printf("通讯录已清空!\n"); } //*************以名字排序所有联系人******** void SORT(Phone p,const size_t num) { qsort(p, num, sizeof(*p), strcmp);//用快排排序必须将结构体第一个成员设为 Name,才可以实现 } //***************菜单****************** void menu() { printf("***********************************************\n"); printf("* MENU *\n"); 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"); printf("***********************************************\n"); printf("请输入选择序号:->"); }
test.c――主函数
#include<stdio.h> #include<stdlib.h> #include<string.h> #include"Phonelist.h" #define MAX 1000 PHONE PEO[MAX] = {0}; int main() { int choose = 1; int i = 0; int ret = 0; while (choose) { menu(); scanf_s("%d", &choose); char name[10]; if (choose >= 0 && choose < 8) { switch (choose) { i = 0; case 1: if (PEO[i].Age == 0 && i < MAX)//设:若Age信息为"0"则对应信息为空 ADD(&PEO[i++]); break; case 2: printf("请输入要删除学生的名字\n"); scanf_s("%s", name, 10); ret = DEL(PEO, name); if (ret == 1) i--; break; case 3: printf("请输入要查找学生的名字\n"); scanf_s("%s", name, 10); SEEK(PEO, name); break; case 4: printf("请输入要修改学生的名字\n"); scanf_s("%s", name, 10); REVISE(PEO, name); break; case 5: SHOW(PEO); break; case 6: FREE_ALL(PEO); break; case 7: SORT(PEO, i - 1); printf("排序结果: \n"); SHOW(PEO); break; default: break; } } } system("pause"); return 0; }