C语言-通讯录

写一个通讯录

要求能够实现增删改查功能,思路如下:

1.定义人的结构体

2.创建通讯录变量

3.初始化通讯录变量

4.增删改查

实现模块:

 

229-contact.h

#define  _CRT_SECURE_NO_WARNINGS  1
#pragma once

#define MAX_NAME 20
#define MAX_SIZE 10
#define MAX_TELE 12
#define MAX_ADDR 30

#define MAX 100

//类型的定义
typedef struct PeoInfo
{
	char name[MAX_NAME];
	char sex[MAX_SIZE];
	int age;
	char tel[MAX_TELE];
	char addr[MAX_ADDR];
}PeoInfo;

//通讯录
typedef struct Contact
{
	PeoInfo data[MAX];//存放添加进来的人信息
	int sz;//记录当前通讯录中有效信息的个数
}Contact;

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

//增加联系人
void AddContact(Contact* pc);

//打印联系人信息
void PrintContact(const Contact* pc);

//删除联系人信息
void DelContact(Contact* pc);

//查找联系人的信息
void SearchContact(Contact* pc);

//修改联系人的信息
void ModifyContact(Contact* pc);

//排序联系人
void SortByName(Contact* pc);

229-contact.c

#define  _CRT_SECURE_NO_WARNINGS  1
#include<stdio.h>
#include "229-contact.h"
#include<string.h>

void InitContact(Contact* pc)
{
	pc->sz = 0;

	//对数组进行初始化,数组名pc->data代表数组首元素的地址,sizeof(数组名)计算的是整个数组的大小
	//     数组首元素地址  数组大小
	memset(pc->data, 0, sizeof(pc->data));
}

void AddContact(Contact* pc)
{
	if (pc->sz == MAX)
	{
		printf("通讯录已满,无法添加\n");
		return;
	}

	//增加一个人的信息
	printf("请输入名字:>");
	scanf("%s", pc->data[pc->sz].name);//数组名是数组首元素的地址,因此name数组不需要加&

	printf("请输入年龄:>");
	scanf("%d", &(pc->data[pc->sz].age));
	
	printf("请输入性别:>");
	scanf("%s", pc->data[pc->sz].sex);
	
	printf("请输入电话:>");
	scanf("%s", pc->data[pc->sz].tel);
	
	printf("请输入地址:>");
	scanf("%s", pc->data[pc->sz].addr);
	
	pc->sz++;

	printf("增加成功\n");
}

void PrintContact(const Contact* pc)
{
	
	//打印标题
	printf("%-20s\t%-5s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");

	//打印数据
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-20s\t%-5d\t%-5s\t%-12s\t%-20s\n",  
			pc->data[i].name,
			pc->data[i].age,
			pc->data[i].sex,
			pc->data[i].tel,
			pc->data[i].addr);
	}
}

static int FindByName(Contact* pc, char name[])//其他源文件不需要查看FindByName,因此用static修饰
{
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		if (strcmp(pc->data[i].name, name) == 0)//字符串比较
		{
			return i;//找到了
		}
	}
	return -1;//没找到
}


void DelContact(Contact* pc)
{
	char name[MAX_NAME] = { 0 };
	//先判空
	if (pc->data == 0)
	{
		printf("通讯录为空,无需删除\n");
		return;
	}

	//1.查找要删除的人
	//有/没有
	printf("请输入要删除的人的名字:>");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (pos == -1)
	{
		printf("要删除的人不存在\n");
		return;
	}
	//2.删除
	//如何删除?如果删除3,把3后面的下标为i的元素放在下标为i-1的位置上,假如最后一个元素下标为9,
	//如果执行data[i+1]就访问越界了,因此i最大不许超过9,会把下标为9也就是最后一个元素移到前一个元素上去,sz--
	int i = 0;
	for (i = pos; i < pc->sz - 1; i++)
	{
		pc->data[i] = pc->data[i + 1];
	}
	pc->sz--;
	printf("删除成功\n");
}

void SearchContact(Contact* pc)
{
	char name[MAX_NAME] = { 0 };
	
	//查找
	//有/没有
	printf("请输入要查找的人的名字:>");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (pos == -1)
	{
		printf("要查找的人不存在\n");
		return;
	}

	//打印标题
	printf("%-20s\t%-5s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");

	//打印数据
	printf("%-20s\t%-5d\t%-5s\t%-12s\t%-20s\n",
			pc->data[pos].name,
			pc->data[pos].age,
			pc->data[pos].sex,
			pc->data[pos].tel,
			pc->data[pos].addr);
	
}


void ModifyContact(Contact* pc)
{
	char name[MAX_NAME] = { 0 };

	//查找
	//有/没有
	printf("请输入要修改的人的名字:>");

	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (pos == -1)
	{
		printf("要修改的人不存在\n");
		return;
	}
	else
	{
		//修改一个人的信息
		printf("请输入名字:>");
		scanf("%s", pc->data[pos].name);//数组名是数组首元素的地址,因此name数组不需要加&

		printf("请输入年龄:>");
		scanf("%d", &(pc->data[pos].age));

		printf("请输入性别:>");
		scanf("%s", pc->data[pos].sex);

		printf("请输入电话:>");
		scanf("%s", pc->data[pos].tel);

		printf("请输入地址:>");
		scanf("%s", pc->data[pos].addr);

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

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

void SortByName(Contact* pc)
{
	//按照名字来排序
	qsort(pc->data, pc->sz, sizeof(pc->data[0]), sort_by_name);
}

229-test.c

#define  _CRT_SECURE_NO_WARNINGS  1
#include<stdio.h>
#include "229-contact.h"

//通讯录
//1.通讯录中能够存放1000个人的信息
//每个人的信息
//名字+年龄+性别+电话+地址
//2.增加人的信息
//3.删除指定人的信息
//4.修改指定人的信息
//5.查找指定人的信息
//6.排序通讯录的信息

void menu()
{
	printf("***************************\n");
	printf("******1.add    2.del   ****\n");
	printf("******3.search 4.modify****\n");
	printf("******5.sort   6.print ****\n");
	printf("******0.exit           ****\n");
	printf("***************************\n");

}

enum Option
{
	EXIT,
	ADD,
	DEL,
	SEARCH,
	MODIFY,
	SORT,
	PRINT
};

int main()
{
	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:
			//查找人的信息
			SearchContact(&con);
			break;
		case MODIFY:
			//修改人的信息
			ModifyContact(&con);
			break;
		case SORT:
			SortByName(&con);
			break;
		case PRINT:
			//打印信息
			PrintContact(&con);
			break;
		case EXIT:
			break;
		default:
			break;
		}
	} while(input);

	return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值