目录
概况
采用C语言来模拟编写一个静态通讯录,就是说输入的内容不能保存下来。
其中主要包含了六大块内容:
联系人的添加
联系人的删除
联系人的查找
联系人的修改
联系人的展示
联系人的排序
完整代码:
首先,我将通讯录分成了三个部分:
1、text.c //通讯录的菜单以及主函数
2、Contact.h //结构体和函数的声明,以及头文件的引用
3、Contact.c //通讯录各种功能函数的实现
Contact.h 结构体和函数的声明,以及头文件的引用
#pragma once #include<stdio.h> #include<string.h> #include<assert.h> #include<stdlib.h> #define MAX_NAME 20 #define MAX_SEX 5 #define MAX_TELE 20 #define MAX_ADDR 30 #define MAX 100 #define _CRT_SECURE_NO_WARNINGS 1 //表示一个人的信息 struct PeoInfo { char name[MAX_NAME]; //姓名 char sex[MAX_SEX]; //性别 char tele[MAX_TELE]; //电话 int age; //年龄 char addr[MAX_ADDR]; //住址 }; struct Contact { struct PeoInfo data[MAX]; int sz ; //表示通讯录中还没有信息 }; //初始化通讯录 void InitContact(struct Contact* pc); //给通讯录添加联系人 void AddContact(struct Contact* pc); //显示通讯录的信息 void ShowContact(const struct Contact* pc); //删除指定联系人 void DelContact(struct Contact* pc); //查找指定联系人 void SearchContact(const struct Contact* pc); //修改指定联系人 void ModifyContact(struct Contact* pc); //排序通讯录 void SortContact(struct Contact* pc);
text.c 通讯录的菜单以及主函数
#include "Contact.h" void menu() { printf("*******************************************\n"); printf("****** 1、add 2、del *********\n"); printf("****** 3、search 4、modify *********\n"); printf("****** 5、show 6、sort *********\n"); printf("****** 0、exit *********\n"); printf("*******************************************\n"); } int main() { int input = 0; //创建通讯录 struct Contact con;//存放通讯录数据 //初始化通讯录 InitContact(&con); do { menu(); printf("请选择>:"); scanf("%d", &input); switch(input) { case 1: AddContact(&con); break; case 2: DelContact(&con); break; case 3: SearchContact(&con); break; case 4: ModifyContact(&con); break; case 5: ShowContact(&con); break; case 6: SortContact(&con); break; case 0: printf("退出通讯录\n"); break; default: printf("选择错误,请重新输入\n"); break; } } while (input); return 0; }
Contact.c 通讯录各种功能函数的实现
#include"Contact.h" void InitContact(struct Contact* pc) { assert(pc);//防止pc是空指针 pc->sz = 0; memset(pc->data, 0, 100 * sizeof(struct PeoInfo));//将pc->里面的100数据的字节数全部赋为0 } void AddContact(struct Contact* pc) { if (pc->sz == MAX) { printf("通讯录已满,无法添加数据\n"); return; } //添加人的信息 printf("请输入名字:>"); scanf("%s", pc->data[pc->sz].name); printf("请输入性别:>"); scanf("%s", pc->data[pc->sz].sex); printf("请输入年龄:>"); scanf("%d", &pc->data[pc->sz].age); printf("请输入电话:>"); scanf("%s", pc->data[pc->sz].tele); printf("请输入住址:>"); scanf("%s", pc->data[pc->sz].addr); pc->sz++; printf("成功添加联系人\n"); } void ShowContact(struct Contact* pc) { int i = 0; printf("%-20s\t%-5s\t%-5s\t%-20s\t%-30s\n", "姓名", "性别", "年龄", "电话", "地址"); for (i = 0; i < pc->sz; i++) { printf("%-20s\t%-5s\t%-5d\t%-20s\t%-30s\n", pc->data[i].name, pc->data[i].sex, pc->data[i].age, pc->data[i].tele, pc->data[i].addr); } } //这里的static表示该函数只能在所在的源文件中使用,其他文件不能使用 static int FindByName(const struct Contact* pc, char name[]) { int i = 0; for (i = 0; i < pc->sz; i++) { if (0 == strcmp(pc->data[i].name, name)) { return i; } } return -1; } void DelContact(struct Contact* pc) { char name[MAX_NAME]; printf("请输入你想要删除人的姓名:>"); scanf("%s", name); int ret = FindByName(pc, name); if (ret == -1) { printf("要删除的人不存在\n"); } else { //删除 int j = 0; for (j = ret; j < pc->sz - 1; j++) { pc->data[j] = pc->data[j + 1]; } pc->sz--; printf("成功删除指定联系人\n"); } } void SearchContact(const struct Contact* pc) { char name[MAX_NAME]; printf("请输入你想要查找人的姓名:>"); scanf("%s", name); //查找一下指定联系人是否存在 int ret = FindByName(pc, name); if (ret == -1) { printf("要查找的人不存在\n"); } else { printf("%-20s\t%-5s\t%-5s\t%-20s\t%-30s\n", "姓名", "性别", "年龄", "电话", "地址"); printf("%-20s\t%-5s\t%-5d\t%-20s\t%-30s\n", pc->data[ret].name, pc->data[ret].sex, pc->data[ret].age, pc->data[ret].tele, pc->data[ret].addr); } } void ModifyContact(struct Contact* pc) { printf("请输入想要修改人的名字:>"); char name[MAX_NAME]; scanf ("%s", name); int ret = FindByName(pc, name); if (ret == -1) { printf("要修改的联系人不存在\n"); } else { printf("请输入名字:>"); scanf("%s", pc->data[ret].name); printf("请输入性别:>"); scanf("%s", pc->data[ret].sex); printf("请输入年龄:>"); scanf("%d", &pc->data[ret].age); printf("请输入电话:>"); scanf("%s", pc->data[ret].tele); printf("请输入住址:>"); scanf("%s", pc->data[ret].addr); printf("修改成功\n"); } } //按照年龄来排序 //int CmpByAge(const void* e1, void* e2) //{ // return ((struct PeoInfo*)e1)->age - ((struct PeoInfo*)e2)->age; //} //按照名字排序 int CmpByName(const void* e1, void* e2) { return strcmp(((struct PeoInfo*)e1)->name , ((struct PeoInfo*)e2)->name); } void SortContact(struct Contact* pc) { qsort(pc->data, pc->sz, sizeof(struct PeoInfo), CmpByName); }