实现一个通讯录(添加/删除/查找/修改/按姓名排序)

实现一个通讯录;

通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址

通讯录功能:

  1. 添加联系人信息
  2. 删除指定联系人信息
  3. 查找指定联系人信息
  4. 修改指定联系人信息
  5. 显示所有联系人信息
  6. 以名字排序所有联系人

包含3个文件:

1.test.c 

测试通讯录

2.contact.c

通讯录的实现

3.contact.h

函数的声明

一. test.c

#include"contact.h"

void menu()
{
		printf("*********************************\n");
		printf("**      1. 添加联系人          **\n");
		printf("**      2. 删除联系人          **\n");
		printf("**      3. 查找联系人          **\n");
		printf("**      4. 修改联系人          **\n");
		printf("**      5. 显示所有联系人      **\n");
		printf("**      6. 按姓名排序联系人    **\n");
		printf("**      0. 退出                **\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->sz = 0;//设置通讯录最初只有0个联系人
	memset(pc->data,0,sizeof(pc->data));//设置内存内容
}

void AddContact(struct Contact* pc)//添加联系人
{
	assert(pc);
	
	if (pc->sz == MAX)
	{
		printf("通讯录已满,无法添加\n");
		return;
	}
	else//增加联系人信息
	{
		printf("请输入姓名:");
		scanf("%s", pc->data[pc->sz].name);
		printf("请输入年龄:");
		scanf("%d", &(pc->data[pc->sz].age));
		printf("请输入性别:");
		scanf("%s", pc->data[pc->sz].sex);
		printf("请输入地址:");
		scanf("%s", pc->data[pc->sz].addr);
		printf("请输入电话:");
		scanf("%s", pc->data[pc->sz].tele);

		pc->sz++;
		printf("添加成功!\n");
	}
}

void ShowContact(Contact* pc)//显示所有联系人
{
	assert(pc);
	int i = 0;
	printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年龄", "性别", "地址", "电话");
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[i].name,
													pc->data[i].age,
													pc->data[i].sex,
													pc->data[i].addr,
													pc->data[i].tele);
	}
}

int FindByName(Contact* pc, char name[])
{
	assert(pc);
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		if (strcmp(pc->data[i].name, name) == 0)
		{
			return i;
		}
	}
	return -1;//找不到的情况
}

void DelContact(struct Contact* pc)//删除联系人
{
	assert(pc);
	char name[NAME_MAX];

	if (pc->sz == 0)
	{
		printf("通讯录为空,无法删除\n");
		return;
	}
	//找到要删除的人
	printf("请输入姓名:\n");
	scanf("%s", name);
	int ret=FindByName(pc, name);
	if (-1 == ret)
	{
		printf("要删除的人不存在\n");
		return;
	}
	else
	{
		int i = 0;
		int del = 0;
		for (i = 0; i < pc->sz; i++)
		{
			if (strcmp(pc->data[i].name, name) == 0)
			{
				del = i;
				break;
			}
		}
		//删除
		for (i = ret; i < pc->sz - 1; i++)
		{
			pc->data[i] = pc->data[i + 1];
		}
		pc->sz--;
		printf("删除成功\n");
	}
}

void SearchContact(const struct Contact* pc)//查找联系人
{
	assert(pc);
	char name[NAME_MAX];
	printf("请输入姓名:");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (-1 == pos)
	{
		printf("要查找的人不存在\n");
		return;
	}
	else
	{
		//打印信息
		printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年龄", "性别", "地址", "电话");

		printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[pos].name,
			pc->data[pos].age,
			pc->data[pos].sex,
			pc->data[pos].addr,
			pc->data[pos].tele);
	}
}

void ModifyContact(struct Contact* pc)//修改联系人
{
	assert(pc);
	char name[NAME_MAX];
	printf("请输入要修改的姓名:");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (-1 == pos)
	{
		printf("要查找的人不存在\n");
		return;
	}
	else
	{
		printf("请输入姓名:");
		scanf("%s", pc->data[pos].name);
		printf("请输入年龄:");
		scanf("%d", &(pc->data[pos].age));
		printf("请输入性别:");
		scanf("%s", pc->data[pos].sex);
		printf("请输入地址:");
		scanf("%s", pc->data[pos].addr);
		printf("请输入电话:");
		scanf("%s", pc->data[pos].tele);

		printf("修改完成\n");
	}
}

void SortContact(Contact* pc)//按姓名排序所有联系人
{
	if (pc->sz <= 0) {
		printf("通讯录中没有联系人,请添加!\n");
	}
	int i = 0;
	int j = 0;
	for (i = 0; i < pc->sz - 1; i++)
	{
		for (j = 0; j < pc->sz - i - 1; j++)
		{
			if (strcmp(pc->data[j].name, (pc->data[j + 1]).name) > 0)
			{
				PeoInfo tmp;
				tmp = pc->data[j];
				pc->data[j] = pc->data[j + 1];
				pc->data[j + 1] = tmp;
			}
		}
		printf("排序成功!\n");
	}
}

三. contact.h

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

#define MAX 1000
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12

typedef struct PeoInfo//人的信息
{
	char name[NAME_MAX];
	int age;
	char sex[SEX_MAX];
	char addr[ADDR_MAX];
	char tele[TELE_MAX];
}PeoInfo;

typedef struct Contact
{
	struct PeoInfo data[MAX];//存放1000个联系人
	int sz;//当前已经放的信息的个数
}Contact;

void InitContact(Contact* pc);

void AddContact(Contact* pc);

void ShowContact(const Contact* pc);

void DelContact(Contact* pc);

void SearchContact(const Contact* pc);

void ModifyContact(Contact* pc);

void SortContact(Contact* pc);

演示效果

猜你喜欢

转载自blog.csdn.net/m0_72000264/article/details/128664759