【无标题】

通讯录的应用

本文主要是利用c语言中的结构体实现一个可以是实现增删改查的通讯录小程序

1、大致思路

首先我们制作一个菜单用来规划所需要实现的功能,简易通讯录主要实现以下七个功能:

1.增加联系人 2.删除联系人 3.查找联系人 4.修改联系人 5.显示联系人

6.排序联系人 7.退出通讯录

那么在知道大致功能后,我们需要创建一个联系人的模板用来存储信息,还有一个通讯录用来存储联系人

2、创建联系人模板与通讯录

#define Name_Max 20
#define Sex_Max 5
#define Tele_Max 20
#define Arr_Max 100

typedef struct PeoInfo
{
	char name[Name_Max];
	int age;
	char sex[Sex_Max];
	char tele[Tele_Max];
} PeoInfo;

typedef struct contact
{
	PeoInfo data[Arr_Max];
	int count;
}contact;

联系人与通讯录均用结构体来实现,结构体内的数组容量用宏定义,方便后期修改。

值得注意的是,我们对结构体加了typedef进行重命名,记得新的名字是打在分号之前。

3、打印菜单

do
	{
		printf("1.add        2.del\n");
		printf("3.search     4.modify\n");
		printf("5.show       6.sort\n");
		printf("0.exit            \n");
		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:
			ExitContact(&con);
			break;
		default:
			printf("选择错误,请重新选择");
			break;
		}
	} while (input);

使用do-while结构打印菜单

在swith内将功能与对应数字绑定,所有功能都有一个函数实现,这样菜单呈现简洁明了。

修改通讯录的值,要用结构体变量的地址,所以函数的指针传的都是变量的地址。

###4、各功能实现

功能一:增加联系人
void AddContact(contact* pc)
{
	assert(pc);
	printf("请输入联系人名字->");
	scanf("%s", pc->data[pc->count].name);
	printf("请输入联系人年龄->");
	scanf("%d", &(pc->data[pc->count].age));
	printf("请输入联系人性别->");
	scanf("%s", pc->data[pc->count].sex);
	printf("请输入联系人电话->");
	scanf("%s", pc->data[pc->count].tele);

	pc->count++;
	printf("增加成功\n");
}

在录入联系人信息之后,记得给通讯录总量加一。

功能二、删除联系人
void DelContact(contact* pc)
{
	assert(pc);
	char arr[Name_Max];
	
	if (pc->count == 0)
	{
		printf("删除失败,通讯录为空\n");
		return;
	}
	printf("请输入要删除的联系人->");
	scanf("%s", &arr);
	for (int i = 0; i < pc->count; i++)
	{
		if (0 == strcmp(pc->data[i].name,arr))
		{
			for (int j = i; j < pc->count; j++)
			pc->data[j] = pc->data[j + 1];
			pc->count--;
			printf("删除成功\n");
			return;
		}
		if(i == pc->count)
		printf("删除失败,找不到该联系人\n");

	}
}

在这里要考虑到通讯录是否为空,或者该联系人是否存在的情况,删除成功后记得对通讯录减一。

功能三、查找联系人
void SearchContact(contact* pc)
{
	assert(pc);
	char arr[Name_Max];
	printf("请输入要查找的联系人->");
	scanf("%s", &arr);
	for (int i = 0; i < pc->count; i++)
	{
		if (0 == strcmp(pc->data[i].name, arr))
		{
			printf("已找到\n");
			printf("%-s\t%-s\t%-s\t%-s\n", "名字", "年龄", "性别", "电话");

			printf("%s\t%d\t%s\t%s\n",
				pc->data[i].name
				, pc->data[i].age,
				pc->data[i].sex
				, pc->data[i].tele);
			break;
		}
	}
}

在这查找到联系人后,最好将联系人的信息打印出来。(更加人性化)

功能四、修改联系人
void ModifyContact(contact* pc)
{
	assert(pc);

	char arr[Name_Max];

	if (pc->count == 0)
	{
		printf("修改失败,通讯录为空\n");
		return;
	}
	printf("请输入要修改的联系人->");
	scanf("%s", &arr);
	for (int i = 0; i < pc->count; i++)
	{
		if (0 == strcmp(pc->data[i].name, arr))
		{
			printf("请输入联系人名字->");
			scanf("%s", pc->data[i].name);
			printf("请输入联系人年龄->");
			scanf("%d", &(pc->data[i].age));
			printf("请输入联系人性别->");
			scanf("%s", pc->data[i].sex);
			printf("请输入联系人电话->");
			scanf("%s", pc->data[i].tele);
			printf("修改成功\n");
			return;
		}
		if (i == pc->count)
			printf("修改失败,找不到该联系人\n");

	}
}
功能六、排序联系人
int cmp_name(const void* e1, const void* e2)
{
	assert(e1 && e2);
	return strcmp(((PeoInfo*)e1)->name, (((PeoInfo*)e2)->name));
}
void SortContact(Contact* pc)
{
	assert(pc);
	qsort(pc->data, pc->sz, sizeof(pc->data[0]), cmp_name);
	printf("排序成功\n");
}

排序功能我们用标准库里自带的qsort进行快排就好了,十分的方便。

总代码

contact.h

#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>


#define Name_Max 20
#define Sex_Max 5
#define Tele_Max 20
#define Arr_Max 100

typedef struct PeoInfo
{
	char name[Name_Max];
	int age;
	char sex[Sex_Max];
	char tele[Tele_Max];
} PeoInfo;

typedef struct contact
{
	PeoInfo data[Arr_Max];
	int count;
}contact;

//初始化通讯录
void InitContact(contact* pc);

//增加
void AddContact(contact* pc);

//展示
void ShowContact(contact* pc);

//删除
void DelContact(contact *pc);

//查找
void SearchContact(contact* pc);

//修改
void ModifyContact(contact* pc);

//排序
void SortContact(contact* pc);

//退出
void ExitContact(contact* pc);

contact.c

#include "contact.h"


void InitContact(contact* pc)
{
	assert(pc);
	pc->count = 0;

	memset(pc->data, 0, sizeof(pc->data));
}

void AddContact(contact* pc)
{
	assert(pc);
	printf("请输入联系人名字->");
	scanf("%s", pc->data[pc->count].name);
	printf("请输入联系人年龄->");
	scanf("%d", &(pc->data[pc->count].age));
	printf("请输入联系人性别->");
	scanf("%s", pc->data[pc->count].sex);
	printf("请输入联系人电话->");
	scanf("%s", pc->data[pc->count].tele);

	pc->count++;
	printf("增加成功\n");
}

void ShowContact(contact* pc)
{
	assert(pc);
	int i = 0;
	printf("%-s\t%-s\t%-s\t%-s\n", "名字","年龄", "性别", "电话");
	for (i = 0; i < pc->count; i++)
	{
		printf("%s\t%d\t%s\t%s\n",
			pc->data[i].name
			, pc->data[i].age,
			pc->data[i].sex
			, pc->data[i].tele);
	}
}


void DelContact(contact* pc)
{
	assert(pc);
	char arr[Name_Max];
	
	if (pc->count == 0)
	{
		printf("删除失败,通讯录为空\n");
		return;
	}
	printf("请输入要删除的联系人->");
	scanf("%s", &arr);
	for (int i = 0; i < pc->count; i++)
	{
		if (0 == strcmp(pc->data[i].name,arr))
		{
			for (int j = i; j < pc->count; j++)
			pc->data[j] = pc->data[j + 1];
			pc->count--;
			printf("删除成功\n");
			return;
		}
		if(i == pc->count)
		printf("删除失败,找不到该联系人\n");

	}
}

void SearchContact(contact* pc)
{
	assert(pc);
	char arr[Name_Max];
	printf("请输入要查找的联系人->");
	scanf("%s", &arr);
	for (int i = 0; i < pc->count; i++)
	{
		if (0 == strcmp(pc->data[i].name, arr))
		{
			printf("已找到\n");
			printf("%-s\t%-s\t%-s\t%-s\n", "名字", "年龄", "性别", "电话");

			printf("%s\t%d\t%s\t%s\n",
				pc->data[i].name
				, pc->data[i].age,
				pc->data[i].sex
				, pc->data[i].tele);
			break;
		}
	}
}

void ModifyContact(contact* pc)
{
	assert(pc);

	char arr[Name_Max];

	if (pc->count == 0)
	{
		printf("修改失败,通讯录为空\n");
		return;
	}
	printf("请输入要修改的联系人->");
	scanf("%s", &arr);
	for (int i = 0; i < pc->count; i++)
	{
		if (0 == strcmp(pc->data[i].name, arr))
		{
			printf("请输入联系人名字->");
			scanf("%s", pc->data[i].name);
			printf("请输入联系人年龄->");
			scanf("%d", &(pc->data[i].age));
			printf("请输入联系人性别->");
			scanf("%s", pc->data[i].sex);
			printf("请输入联系人电话->");
			scanf("%s", pc->data[i].tele);
			printf("修改成功\n");
			return;
		}
		if (i == pc->count)
			printf("修改失败,找不到该联系人\n");

	}
}

int cmp_name(const void* e1, const void* e2)
{
	assert(e1 && e2);
	return strcmp(((PeoInfo*)e1)->name, (((PeoInfo*)e2)->name));
}

void SortContact(contact* pc)
	{
		assert(pc);
		qsort(pc->data, pc->count, sizeof(pc->data[0]), cmp_name);
		printf("排序成功\n");

	}


void ExitContact(contact* pc)
{
	printf("退出通讯录");
}

test.c

#include "contact.h"
#define _CRT_SECURE_NO_WARNINGS 1

int main()
{
	contact con;
	InitContact(&con);
	int input = 0;
	do
	{
		printf("1.add        2.del\n");
		printf("3.search     4.modify\n");
		printf("5.show       6.sort\n");
		printf("0.exit            \n");
		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:
			ExitContact(&con);
			break;
		default:
			printf("选择错误,请重新选择");
			break;
		}
	} while (input);
	return 0;
}

总结

对于一个单机的简单的通讯录就做出来了,但是和实际生活运用还是有很大差别的,所有后面再有两种方法对该通讯录进行相应的完善。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值