仅在CMD窗口建立的通讯录(通讯录初级,后期可在此基础上进行动态内存开辟和加入对文件的读写操作)

1:contact.h头文件(不做文字描述,相关介绍均在注释中,用以各功能函数的声明)

#pragma once
#define NAME_MAX 50
#define SEX_MAX 10
#define MAX 1000
#define ADDR_MAX 50
#define TEL_MAX 20
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
//每个联系人的信息
struct PeopInfo
{
	char name[NAME_MAX];
	int age;
	char tel[TEL_MAX];
	char sex[SEX_MAX];
	char addr[ADDR_MAX];	
};
//创建一个结构体,让这个结构体可以包含容量为MAX个人的信息,即通讯录
struct contact
{
	struct PeopInfo data[MAX];
	int sz;
};
//初始化通讯录
void InitContact(struct contact* pc);
//添加联系人信息
void AddContact(struct contact* pc);
//展示通讯录
void ShowContact(struct contact* pc);
//删除联系人信息
void DelContact(struct contact* pc);
//查找联系人
void SearchContact(struct contact* pc);
//修改联系人信息
void ModifyContact(struct contact* pc);
//按照年龄进行排序
void SortByAge(struct contact* pc);

2.contact.c(通讯录各功能的定义)

#include "contact.h"
//初始化通讯录
void InitContact(struct contact* pc)
{
	pc->sz = 0;
	memset(pc->data, 0, sizeof(struct PeopInfo[MAX]));//全部置为0
}
//添加联系人信息
void AddContact(struct contact* pc)
{
	//要先判断通讯录是否已满?
	if (pc->sz != MAX)
	{
		//添加
		printf("请输入联系人姓名:>");
		scanf("%s", pc->data[pc->sz].name);
		printf("请输入联系人的年龄:>");
		scanf("%d", &(pc->data[pc->sz].age));
		printf("请输入联系人的电话:>");
		scanf("%s", pc->data[pc->sz].tel);
		printf("请输入联系人的性别:>");
		scanf("%s", pc->data[pc->sz].sex);
		printf("请输入联系人的地址:>");
		scanf("%s", pc->data[pc->sz].addr);
		printf("添加完成!\n");
		pc->sz++;//每添加一个人,有效信息个数就加一
	}
	else
	{
		printf("通讯录已满!\n");
		return;
	}
}
//展示通讯录
void ShowContact(struct contact* pc)
{
	//先展示一个表头
	printf("%-15s\t%5s\t%15s\t\t%5s\t%20s\n","姓名","年龄","电话","性别","地址");//姓名、年龄、电话、性别、地址
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-15s\t%5d\t%15s\t\t%5s\t%20s\n", pc->data[i].name, pc->data[i].age, pc->data[i].tel, pc->data[i].sex, pc->data[i].addr);
	}
}
//删除联系人信息
//查找联系人(依据联系人的姓名)
int FindByName(struct contact* pd,char* name)
{
	//遍历式查找
	int i = 0;
	for (i = 0; i < pd->sz; i++)
	{
		if (strcmp(pd->data[i].name, name) == 0)
		{
			return i;
		}
	}
	return -1;
}
void DelContact(struct contact* pc)
{
	//通讯录为空肯定没法删除联系人
	if (pc->sz == 0)
	{
		printf("通讯录为空,无法删除\n");
		return;
	}
	else
	{
		//删除也要利用一个信息去找到那个人,然后再去把他删除,这里使用一个人的姓名
		char name[NAME_MAX];
		printf("请输入要删除的联系人的姓名:>");
		scanf("%s", name);
		int tmp=FindByName(pc,name);//靠姓名在通讯录中查找这个人
		if (tmp == -1)
		{
			printf("查无此人\n");
		}
		else
		{
			//进行删除
			//用后面人的信息覆盖要被删除联系人的信息
			int j = 0;
			for (j = tmp; j < pc->sz - 1; j++)
			{
				pc->data[j] = pc->data[j + 1];//这种操作注意一下,实现一个数组的覆盖
			}
			//覆盖完,通讯录的有效信息应当减一
			pc->sz--;//这里其实可以保证只有一个联系人时,showcontact不会打印联系人信息,相当于删除了一个联系人
			//而如果是检索到的是通讯录最后一个联系人的话,同理不会被打印,也相当于删除了一个联系人,其余均为一般情况
			printf("联系人删除成功!\n");
		}
	}
}
//查找联系人
void SearchContact(struct contact* pc)
{
	//这里依据姓名进行查找,其实和findbyname是一样的
	char name[NAME_MAX];
	printf("请输入你想要查找的联系人姓名:>");
	scanf("%s", name);
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		if (strcmp(pc->data[i].name, name) == 0)
		{
			printf("%-15s\t%5s\t%15s\t\t%5s\t%20s\n", "姓名", "年龄", "电话", "性别", "地址");
			printf("%-15s\t%5d\t%15s\t\t%5s\t%20s\n", pc->data[i].name, pc->data[i].age, pc->data[i].tel, pc->data[i].sex, pc->data[i].addr);
			return;//找到了,直接结束查找函数即可
		}
	}
	printf("查无此人\n");
}
//修改联系人信息
void ModifyContact(struct contact* pc)
{
	//要修改联系人信息,就得先找到指定联系人,这里依旧依据姓名进行查找
	char name[NAME_MAX];
	printf("请输入需要修改信息人的姓名:>");
	scanf("%s", name);
	int tmp = FindByName(pc, name);
	if (tmp == -1)
	{
		printf("查无此人\n");
		return;
	}
	else
	{
		printf("请输入联系人姓名:>");
		scanf("%s", pc->data[tmp].name);
		printf("请输入联系人的年龄:>");
		scanf("%d", &(pc->data[tmp].age));
		printf("请输入联系人的电话:>");
		scanf("%s", pc->data[tmp].tel);
		printf("请输入联系人的性别:>");
		scanf("%s", pc->data[tmp].sex);
		printf("请输入联系人的地址:>");
		scanf("%s", pc->data[tmp].addr);
		printf("修改成功\n");
	}
}
//按照年龄进行排序
int compare(const void* e1, const void* e2)
{
	return *(int*)e1 - *(int*)e2;
}
void SortByAge(struct contact* pc)
{
	//用之前学的qsort()函数:void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );
	qsort(pc->data, pc->sz, sizeof(pc->data[0]), compare);
	printf("按年龄升序排序成功\n");
}

3.test.c(用以测试通讯录是否实现,相关介绍均在注释中)

#include <stdio.h>
#include "contact.h"
void menu()
{
	printf("*****************************\n");
	printf("*****0.exit    1.add   ******\n");
	printf("*****2.del     3.search******\n");
	printf("*****4.modify  5.show  ******\n");
	printf("*****6.sort            ******\n");
}
enum Option
{
	EXIT,
	ADD,
	DEL,
	SEARCH,
	MODIFY,
	SHOW,
	SORT
};
int main()
{
	//创建一个通讯录
	struct contact con;
	//对con进行初始化
	InitContact(&con);
	int input = 0;
	do
	{
		menu();
		printf("请输入你的选择:>");
		scanf("%d", &input);
		switch (input)
		{
		case EXIT:
			printf("已退出通讯录\n");
			break;
		case ADD:
			AddContact(&con);
			break;
		case DEL:
			DelContact(&con);
			break;
		case SEARCH:
			SearchContact(&con);
			break;
		case MODIFY:
			ModifyContact(&con);
			break;
		case SHOW:
			ShowContact(&con);
			break;
		case SORT:
			SortByAge(&con);//顾名思义
			break;
		default:
			printf("输入有误,请重新输入:>");
			break;
		}
	} while (input);
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值