在我们学习一门编程语言的时候,不可避免地会找一些小项目练手,一方面检验自己学习成果,另一方面可以巩固以前所学的知识。而通讯录是很多人都会尝试练习的。今天,将该项目分享出来供大家学习、查阅。其中各功能经过本人的实验均能够实现,还请大家放心“食用“,若有不妥、错误和可以改进的地方,欢迎大家指出!
该通讯录具体描述及功能如下:
具体描述:
通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址。
主要功能:
1.添加联系人信息
2.删除指定联系人信息
3.查找指定联系人信息
4.修改指定联系人信息
5.显示所有联系人信息
6.清空所有联系人
7.按姓名将联系人排序
分三个模块来实现:头文件包含模块、功能实现模块、测试模块
思路分析:
- 头文件模块(function.h)主要用于对所用到的库函数所在的头文件进行声明,定义通讯录内容(个人信息和当前存储的人数),定义和个人信息(姓名、年龄、性别、电话、地址),和各个功能函数的声明。
- 功能实现模块(function.c)主要对联系人的增、删、查、改等功能进行函数的实现。
- 测试模块(test.c),包括菜单的打印、通过不同的输入调用不同函数,实现不同的功能。
C语言实现代码
function.h模块
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define N 1000//s数组中包含的人数
#define NAME 20//名字中的字符个数
#define SEX 10//性别的字符个数
#define TELE 11 //电话号码中的位数
#define DRESS 30//地址中的字符个数
//创建一个结构体,包含一个学生的信息
typedef struct People
{
/*个人信息姓名、性别、年龄、电话、住址*/
char name[NAME];
char sex[SEX];
int age;
char tele[TELE];
char strdess[DRESS];
}Peo;
//创建一个通讯录结构提,用包含学生数组和人数
typedef struct contact
{
Peo arrpeo[N];
int num;
}Conpeo;
//初始化联系人
void Initpeo(Conpeo* str);
//添加联系人信息
void Addpeople(Conpeo* str);
//显示所有联系人信息
void Dispalypeo(Conpeo* str);
//删除联系人信息
void Delepeo(Conpeo* str);
//修改指定联系人信息
void Xiugaipeo(Conpeo* str);
//查找并显示指定联系人的信息
void seach_dispalupeo(Conpeo * str);
//清空所有联系人
void Dispempeo(Conpeo* str);
//按姓名排序联系人
void sort_peo(Conpeo * str);
function.c部分
#define _CRT_SECURE_NO_WARNINGS 1
#include"function.h"
/*函数功能的实现*/
//初始化
void Initpeo(Conpeo* str)
{
str->num = 0;//个数为0
//对结构体内的数据进行初始化时,用memset函数,因为数组的大小是不知道的
memset(str->arrpeo, 0, sizeof(str->arrpeo));
}
//添加联系人信息
void Addpeople(Conpeo* str)
{
//联系人已满
if (str->num == N)
{
printf("通讯录已满,不能增加");
return;
}
//联系人未满
else
{
printf("请输入联系人姓名:");
scanf("%s", str->arrpeo[str->num].name);
printf("请输入联系人性别:");
scanf("%s", str->arrpeo[str->num].sex);
printf("请输入联系人年龄:");
scanf("%d", &(str->arrpeo[str->num].age));
printf("请输入联系人电话:");
scanf("%s", str->arrpeo[str->num].tele);
printf("请输入联系人地址:");
scanf("%s", str->arrpeo[str->num].strdess);
}
str->num++;
}
//显示联系人信息
void Dispalypeo(Conpeo* str)
{
//列表为空时
if (str->num == 0)
{
printf("列表为空,没有联系人!\n");
}
else
{
printf("%-20s %-5s %-5s %-12s %-20s\n", "姓名", "性别", "年龄", "电话", "地址");
for (int i = 0; i < str->num; i++)
{
printf("%-20s %-5s %-5d %-12s %-20s\n", str->arrpeo[i].name, str->arrpeo[i].sex, str->arrpeo[i].age, str->arrpeo[i].tele, str->arrpeo[i].strdess);
}
}
}
//查找指定联系人
int Seachpeo(Conpeo* str,char name[])
{
//没有联系人
if (str->num == 0)
{
printf("列表为空,没有联系人\n");
return -1;
}
else
{
for (int i = 0; i < str->num; i++)
{
//字符串的比较
if (strcmp(str->arrpeo[i].name, name) == 0)
{
//输出所查找的联系人,所在下标
return i;
}
}
return -1;
}
}
//查找并显示指定联系人的信息
void seach_dispalupeo(Conpeo* str)
{
char name[NAME] = { 0 };
printf("请输入需要查找的联系人姓名:");
scanf("%s", name);
if (str->num == 0)
{
printf("联系人列表是空的。\n");
}
int pos = Seachpeo(str, name);
if (pos == -1)
{
printf("该联系人不存在!\n");
}
else
{
printf("查找的联系人,信息如下:\n");
printf("%-20s %-5s %-5s %-12s %-20s\n", "姓名", "性别", "年龄", "电话", "地址");
printf("%-20s %-5s %-5d %-12s %-20s\n", str->arrpeo[pos].name, str->arrpeo[pos].sex, str->arrpeo[pos].age, str->arrpeo[pos].tele, str->arrpeo[pos].strdess);
}
}
//删除联系人信息
void Delepeo(Conpeo* str)
{
//没有联系人
if (str->num == 0)
{
printf("联系人列表为空,无法删除。\n");
return;
}
//有联系人
else
{
printf("请输入要删除人的姓名。\n");
char name[NAME] = { 0 };
scanf("%s", name);
if (Seachpeo(str, name) == -1)
{
printf("该联系人不存在\n");
}
else
{
for (int i = Seachpeo(str, name); i < str->num; i++)
{
//删除的该联系人,从左向右,后面的数据往前移
str->arrpeo[i] = str->arrpeo[i + 1];
}
printf("该联系人已删除\n");
str->num--;
}
}
}
//修改指定联系人信息
void Xiugaipeo(Conpeo* str)
{
//没有联系人
if (str->num == 0)
{
printf("没有联系人\n");
return;
}
else
{
char name[NAME];
printf("请输入要修改的联系人姓名\n");
scanf("%s", name);
int pos = Seachpeo(str, name);
if (pos == -1)
{
printf("该联系人不存在\n");
return;
}
//修改联系人的信息
printf("请输入修改后的联系人信息:\n");
printf("请输入姓名:\n");
scanf("%s", str->arrpeo[pos].name);
printf("请输入性别:\n");
scanf("%s", str->arrpeo[pos].sex);
printf("请输入年龄:\n");
scanf("%d", &str->arrpeo[pos].age);
printf("请输入电话:\n");
scanf("%s", str->arrpeo[pos].tele);
printf("请输入地址:\n");
scanf("%s", str->arrpeo[pos].strdess);
printf("修改成功!\n");
}
}
//清空所有联系人
void Dispempeo(Conpeo* str)
{
str->num = 0;
printf("已经清空联系人列表,现在该列表为空!\n");
}
//按姓名排序联系人
void sort_peo(Conpeo* str)
{
int i = 0;
int j = 0;
for (i = 0; i < str->num; i++)
{
for (j = 0; j < str->num - 1 - i; j++)
{
if (strcmp(str->arrpeo[j].name, str->arrpeo[j + 1].name) > 0)
{
Peo tem = str->arrpeo[j];
str->arrpeo[j] = str->arrpeo[j + 1];
str->arrpeo[j + 1] = tem;
}
}
}
printf("排序成功!\n");
}
test.c部分
#include"function.h"
//打印菜单
menu()
{
printf("*****************************************\n");
printf("********1.添加联系人 2.删除联系人*******\n");
printf("********3.查找联系人 4.修改联系人*******\n");
printf("********5.显示联系人 6.清空联系人*******\n");
printf("********7.排序联系人 0.退出 *******\n");
printf("*****************************************\n");
}
enum Option
{
EXIT,
ADD,
DELE,
SEACH,
XIUGAI,
DISPALY,
DISPEM,
SORT,
};
int main()
{
int input;//功能选择
Conpeo conpeo;//创建通讯录变量
Initpeo(&conpeo);
do
{
menu();
printf("请选择:");
scanf("%d", &input);
switch (input)
{
case EXIT:
printf("操作完成,请推出!");
break;
case ADD:
Addpeople(&conpeo);
break;
case DELE:
Delepeo(&conpeo);
break;
case SEACH:
seach_dispalupeo(&conpeo);
break;
case XIUGAI:
Xiugaipeo(&conpeo);
break;
case DISPALY:
Dispalypeo(&conpeo);
break;
case DISPEM:
Dispempeo(&conpeo);
break;
case SORT:
sort_peo(&conpeo);
break;
default:
printf("选择错误,请重新选择!");
break;
}
} while (input);
return 0;
}