C语言实现简易版通讯录功能

大家好!我会按照自己的学习进度,不定时更新博客,请大家多多支持!

文章目录

  • 前言
  • 一、代码实现
  • 总结


前言

当我们学习结构体类型之后,就可以用它来实现一个小型项目------通讯录,当然是十分简易版,有很多的瑕疵,比如每次程序退出之后,上次的数据由于存在内存中,一旦程序结束,操作系统将内存回收,数据就丢失了,如果想要保留上次的数据,我们需要将数据保存到一个文件中(硬盘)上。以后我们再编写一个优化的程序。

一、

//各种函数,头文件,结构体类型的声明
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
#define NAME_MAX 20
#define SEX_MAX 10
#define TEL_MAX 12 
#define ADDR_MAX 30

extern void menu();
typedef struct people
{
	char name[NAME_MAX];
	int age;
	char sex[SEX_MAX];
	char tel[TEL_MAX];
	char addr[ADDR_MAX];
}people;
typedef struct Contact
{
    people data[100];
	int count;
}Contact;
extern void AddContact(Contact* con);
extern void DelContact(Contact* con);
extern void SearchContact(Contact* con);
extern void ModifyContact(Contact* con);
extern void ShowContact(Contact* con);

//函数功能的实现

#define _CRT_SECURE_NO_WARNINGS
#include"test.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");
}
static int FindContact(Contact* con,char*name)
{
	int i = 0;
	for (i = 0; i < con->count; i++)
	{
		if (strcmp(con->data->name, name) == 0)
		{
			return i;
		}
	}
	return -1;
}
//增加
void AddContact(Contact* con)
{
	assert(con);
	if (con->count == 100)
	{
		printf("通讯录已满\n");
		return;
	}
	printf("请输入姓名:>");
	scanf("%s", con->data[con->count].name);
	printf("请输入年龄:>");
	scanf("%d", &(con->data[con->count].age));
	printf("请输入性别:>");
	scanf("%s", con->data[con->count].sex);
	printf("请输入电话号:>");
	scanf("%s", con->data[con->count].tel);
	printf("请输入地址:>");
	scanf("%s", con->data[con->count].addr);
	(con->count)++;
	printf("增加成功\n");
}
//删除
void DelContact(Contact* con)
{
	assert(con);
	printf("请输入要删除的人的名字:>\n");
	char name[NAME_MAX];
	scanf("%s", name);
	int k = FindContact(& con,name);
	if (k == -1)
	{
		printf("未查询到此人\n");
		return;
	}
	int i = k;
	for (i = k; i < con->count-1; i++)
	{
		con->data[i] = con->data[i + 1];
	}
	con->count--;
	printf("删除成功\n");
}
//查找
void SearchContact(Contact* con)
{
	assert(con);
	printf("请输入要查找的人的名字:>\n");
	char name[NAME_MAX];
	int k = FindContact(&con, name);
	if (k == -1)
	{
		printf("未查询到此人\n");
		return;
	}
	printf("找到了\n");
}
//修改
void ModifyContact(Contact* con)
{
	printf("请输入要修改的人的名字:>\n");
	char name[20];
	scanf("%s", name);
	int k = FindContact(&con, name);
	if (k == -1)
	{
		printf("要修改的人不存在\n");
		return;
	}
	printf("请输入姓名:>");
	scanf("%s", con->data[k].name);
	printf("请输入年龄:>");
	scanf("%d", &(con->data[k].age));
	printf("请输入性别:>");
	scanf("%s", con->data[k].sex);
	printf("请输入电话号:>");
	scanf("%s", con->data[k].tel);
	printf("请输入地址:>");
	scanf("%s", con->data[k].addr);
	printf("修改成功\n");
}
//展示
void ShowContact(Contact* con)
{
	printf("%-12s\t%-5s\t%-10s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
	int i = 0;
	for (i = 0; i < con->count; i++)
	{
		printf("%-12s\t%-5d\t%-10s\t%-12s\t%-20s\n",
			con->data[i].name,
			con->data[i].age,
			con->data[i].sex,
			con->data[i].tel,
			con->data[i].addr);
	}
}
//排序
int SortByname(const void* p1, const void* p2)
{
	return strcmp(((people*)p1)->name, ((people*)p2)->name);
}
void SortContact(Contact* con)
{
	assert(con);
	qsort(con->data, con->count, sizeof(con->data[0]), SortByname);
}
//程序主体
#include"test.h"
int main()
{
	int input = 0;
	Contact con = {0};
	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;
}

二.总结

以上是实现的全部代码,由于我是分模块去写的,所以需要三个文件。希望对您有所收获!

感谢观看,铁汁们,点赞加关注哦!

你可能感兴趣的:(c语言,开发语言,算法,visualstudio,c++)