通讯录1(静态)

该代码实现了一个通讯录系统,支持添加、删除、查找、修改、打印联系人信息,以及按姓名排序和清空所有联系人。使用结构体存储联系人信息,包括姓名、性别、年龄、电话和地址。程序通过菜单驱动,用户交互操作通讯录。
摘要由CSDN通过智能技术生成

下面是我自己实现的,对于排序和清空这两块我自己不确定,若有错误请指正,谢谢啦!
实现一个通讯录;

通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址
添加联系人信息
删除指定联系人信息
查找指定联系人信息
修改指定联系人信息
显示所有联系人信息
清空所有联系人
以名字排序所有联系人

测试文件.C

#define _CRT_SECURE_NO_WARNINGS 1
#pragma warning(disable:6031)

#include "通讯录.h"
enum option
{
	EXIT,//0
	ADD,
	DEL,
	SEARCH,
	MODIFY,
	PRINT,
	EMPTY,
	SORT

};

void menu()
{

	printf("*******1.add添加    2.del删除***********\n");
	printf("*******3.search查找 4.modify修改********\n");
	printf("*******5.print打印  6.empty清空联系人****\n");
	printf("****7.sort以名字排序所有联系人0.exit**********\n");
}
void test()
{
	int input = 0;
	//创建通讯录
	contact con;//通讯录
	//初始化通讯录
	Initcontact(&con);
	do
	{
		menu();
		printf("请选择->");
		scanf("%d", &input);
		switch (input)
		{
		case ADD:
			addcontact(&con);
			break;
		case DEL:
			delcontact(&con);
			break;
		case SEARCH:
			break;
		case MODIFY:
			break;
		case PRINT:
			printcontact(&con);
			break;
		case EMPTY:
			emptycontact(&con);
			break;
		case SORT:
			sortcontact(&con);
			break;
		case EXIT:
			printf("退出通讯录\n");
			break;
		default:
			printf("选择错误请重新选择\n");
			break;
		}

	} while (input);

}

int main()
{
	test();
	return 0;
}

头文件.h

#define _CRT_SECURE_NO_WARNINGS 1
#pragma warning(disable:6031)
#include <stdio.h>
#include <string.h>
#include <assert.h>
#include <stdlib.h>


#define MAX 20
#define NAME_MAX 20
#define	SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30
//类型的声明
typedef struct type
{
	char name[NAME_MAX];//名字
	char sex[SEX_MAX];//性别
	int age;//年龄
	char tele[TELE_MAX];//电话
	char addr[ADDR_MAX];//地址

}type;

//通讯录的声明
typedef struct contact
{
	type date[MAX];//创建1000个人的信息
	int sz;//记录通讯录中已保存的信息个数
}contact;

//初始化通讯录
void Initcontact(contact* pc);
//添加联系人
void addcontact(contact* pc);
//打印通讯录
void printcontact(const contact* pc);
//删除联系人
void delcontact(contact* pc);
//清空联系人
void emptycontact(contact* pc);
//按照人名排序联系人
void sortcontact(contact* pc);

执行文件.c

#define _CRT_SECURE_NO_WARNINGS 1
#pragma warning(disable:6031)

#include "通讯录.h"
void Initcontact(contact* pc)
{
	assert(pc);
	memset(pc->date, 0, sizeof(pc->date));
	pc->sz = 0;
}
void addcontact(contact* pc)
{
	assert(pc);
	//录入信息
	printf("请输入名字:>");
	scanf("%s", pc->date[pc->sz].name);//pc->date[pc->sz].name  sz为date下标  name是个数组,数组名就是地址
	printf("请输入性别:>");
	scanf("%s", pc->date[pc->sz].sex);
	printf("请输入年龄:>");
	scanf("%d", &(pc->date[pc->sz].age));//%d,要加&
	printf("请输入电话:>");
	scanf("%s", pc->date[pc->sz].tele);
	printf("请输入地址:>");
	scanf("%s", pc->date[pc->sz].addr);
	pc->sz++;
	printf("添加成功\n");
}

//打印通讯录
void printcontact(const contact* pc)
{
	assert(pc);
	int i = 0;
	printf("%-15s %-5s %-5s %-12s %-30s\n", "名字", "性别", "年龄", "电话", "地址");
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-15s %-5s %-5d %-12s %-30s\n", pc->date[i].name, pc->date[i].sex, pc->date[i].age, pc->date[i].tele, pc->date[i].addr);
	}

}

//找到后返回下标
//没找到返回-1
int FineByName(contact* pc, char name[])
{
	assert(pc);
	//字符串比较大小用strcmp
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		if (0 == strcmp(pc->date[i].name, name))
			return i;
	}
	return -1;
}

//删除联系人
void delcontact(contact* pc)
{
	assert(pc);
	//没有联系人
	if (0 == pc->sz)
	{
		printf("无联系人,无法删除\n");
		return;
	}
	//删除
	//1.找到联系人
	char name[NAME_MAX] = { 0 };
	printf("请输入删除人的名字:");//不考虑重名
	scanf("%s", name);
	int pos = FineByName(pc, name);
	if (pos == -1)
	{
		printf("不存在这个名字\n");
		return;
	}
	//2.删除,后面的覆盖前面的,可以用memmove
	int j = 0;
	for (j = pos; j < pc->sz - 1; j++)//pc->sz时,sz最大=1000,j=999,j+1=1000,date[1000]越界了。当为pc->sz-1时,最大j=998,j+1=999可以拿过去
	{
		pc->date[j] = pc->date[j + 1];
	}
	pc->sz--;// 假若j = 999,sz--,会把最后一个元素删掉,访问不到了
	printf("删除成功\n");
}


//清空联系人
void emptycontact(contact* pc)
{
	assert(pc);
	//没有联系人
	if (0 == pc->sz)
	{
		printf("无联系人,无法清空\n");
		return;
	}
	//清空
	memset(pc->date, 0, sizeof(pc->date));
	pc->sz = 0;
	printf("清空成功\n");
	
}


int q_arr1_name(const void* e1, const void* e2)
{
	return strcmp(((type*)e1)->name, ((type*)e2)->name);
}
//按照人名排序联系人
void sortcontact(contact* pc)
{
	qsort(pc->date, pc->sz, sizeof(pc->date[pc->sz]), q_arr1_name);
	printf("排序成功\n");
	//sizeof(pc->date[0])也可
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值