目录
题目描述:
运用c语言编写一个类似于手机通讯录的代码,需要涉及添加,删除,查找,修改,显示,排列等功能。
解题思路:
9.24.1.c 通讯录的菜单以及主函数
9.24.2.c 各种功能的实现
9.24.1.h 函数和结构体的声明,以及头文件的引用
完整代码:
9.24.1.h 函数和结构体的声明,以及头文件的引用
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h> #include<assert.h> #include<stdlib.h> #define MAX 100 #define MAX_NAME 20 #define MAX_SEX 15 #define MAX_TELE 12 #define MAX_ID 30 struct perimformation {//个人信息 char name[MAX_NAME];//姓名 char sex[MAX_SEX];//性别 char tele[MAX_TELE];//电话号码 int age;//年龄 char id[MAX_ID];//身份证 }; struct Contact { struct perimformation data[MAX]; int sz; }; void Int_Contact(struct Contact* pc);//初定义结构体 void ADD_Contact(struct Contact *pc);//添加个人信息 void Show_Contact(struct Contact* pc);//展示个人信息 void Del_Contact(struct Contact* pc);//删除个人信息 void Search_Contact(struct Contact* pc);//查找个人信息 void Modify_Contact(struct Contact* pc);//修改个人信息 void Sort_Contact(struct Contact* pc);//排序个人信息
9.24.1.c 通讯录的菜单以及主函数
#include"9.24.1.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;//创建通讯录 Int_Contact(&con);//初始化通讯录 do { menu(); printf("请选择->:\n"); scanf("%d", &input); switch (input) {//创建通讯录 case 1: ADD_Contact(&con); break; case 2: Del_Contact(&con); break; case 3: Search_Contact(&con); break; case 4: Modify_Contact(&con); break; case 5: Show_Contact(&con); break; case 6: Sort_Contact(&con); break; case 0: printf("退出通讯录\n"); break; default: printf("选择错误,重新选择\n"); break; } }while (input); return 0; }
9.24.2.c 各种功能的实现
#include"9.24.1.h" void Int_Contact(struct Contact* pc) {//初始化结构体 assert(pc); pc->sz = 0; memset(pc->data, 0, MAX * sizeof(struct perimformation)); } void ADD_Contact(struct Contact* pc) {//增加通讯录的信息 assert(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("%s", pc->data[pc->sz].tele); printf("请输入年龄:"); scanf("%d", &(pc->data[pc->sz].age)); printf("请输入身份证:"); scanf("%s", pc->data[pc->sz].id); pc->sz++; printf("信息添加成功\n"); } void Show_Contact(const struct Contact* pc) {//显示身份信息 int i = 0; printf("%-20s\t%-15s\t%-12s\t%-5s\t%-30s\n", "名字","性别","电话","年龄","身份证"); for (int i = 0; i < pc->sz; i++) { printf("%-20s\t%-15s\t%-12s\t%-5d\t%-30s\n", pc->data[i].name, pc->data[i].sex, pc->data[i].tele, pc->data[i].age, pc->data[i].id); } } int FindbyNAME(struct Contact* pc, char NAME[]) { int i = 0; for (int i = 0; i < pc->sz; i++) { if (0 == strcmp(pc->data[i].name, NAME)) { return i; } } return -1; } void Del_Contact(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 (int j = ret; j < pc->sz - 1; j++) { pc->data[j] = pc->data[j + 1]; } pc->sz--; printf("成功删除指定联系人\n"); } } void Search_Contact(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%-15s\t%-12s\t%-5s\t%-30s\n", "名字", "性别", "电话", "年龄", "身份证"); printf("%-20s\t%-15s\t%-12s\t%-5d\t%-30s\n", pc->data[ret].name, pc->data[ret].sex, pc->data[ret].tele, pc->data[ret].age, pc->data[ret].id); } } void Modify_Contact(struct Contact* pc) { char NAME[MAX_NAME]; printf("请输入要修改的人的名字"); 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("%s", pc->data[ret].tele); printf("请输入年龄:"); scanf("%d", &(pc->data[ret].age)); printf("请输入身份证:"); scanf("%s", pc->data[ret].id); printf("信息修改成功\n"); } } int cmp_name(const void* e1, const void* e2) {//以名字排序 return strcmp(((struct perimformation*)e1)->name, ((struct perimformation*)e2)->name); } int cmp_age(void* e1, void* e2) {//以年龄排序 return ((struct perimformation*)e1)->age-((struct perimformation*)e2)->age; } void Sort_Contact(struct Contact* pc) {//排序 qsort(pc->data, pc->sz, sizeof(struct perimformation), cmp_name);