C语言实现通讯录

今天分享一个通讯录的代码,代码可以正常运行,但是可能有一点点缺陷,完成的是我们的通讯录功能

contact.h

c 复制代码
#pragma once
#include<string.h>

#include<stdio.h>
#include<assert.h>
#define MAX 1000
#define NAME_MAX 20
#define SEX_MAX 5
#define TEL_MAX 12
#define ADDR_MAX 30
typedef struct people
{
	char name[NAME_MAX];//名字
	char sex[SEX_MAX];//性别
	int age;//年龄
	char tel[TEL_MAX];//电话
	char addr[ADDR_MAX];//地址
}people;//定义这个struct people为people


typedef struct contact
{
	people data[MAX];//存放一千个人信息
	int sz;//记录通讯录已经保存的信息个数
}contact;

enum optiom 
{
	EXIT,
	ADD,
	DEL,
	SEARCH,
	MODIFY,
	SORT,
	PRINT
};
//初始化通讯录
void Initcontact(contact* pc);

//添加用户信息
void AddContact(contact* pc);

//打印信息
void PrintContact(const contact* pc);

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

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


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


//排序功能没写

contact.c

c 复制代码
#define _CRT_SECURE_NO_WARNINGS 1

#include"contact.h"
//初始化通讯录
void Initcontact(contact* pc)
{
	pc->sz = 0;
	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);
	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);
	//把数据放入下标为sz的底下
	pc->sz++;
	//不能单独 写sz++

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

void PrintContact(const contact* pc)
{
	assert(pc);
	int i = 0;
	printf("%-20s  %-10d  %-5s  %-12s  %-30s\n","姓名","年龄","性别","电话","地址");
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-20s  %-10d  %-5s  %-12s  %-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tel, pc->data[i].addr);
	}
	
}

int FindName(contact* pc, char name[])
{
	int i = 0;
	for (i = 0; i < pc->sz; i++)
	{
		if (0 == strcmp(name, pc->data[i].name))
		{
			return i;
		}
	}
	return -1;
}
void DelContact(contact* pc)
{
	assert(pc);
	if (pc->sz == 0)
	{
		printf("通讯录已空,无法删除\n");
		return;
	}
	char name[NAME_MAX] = { 0 };
	printf("要删除的人>");
	scanf("%s", name);
	int pos = FindName(pc, name);
	if (pos ==-1)
	{
		printf("要删除的人不存在\n");
	}
	int j = 0;
	for (j = pos; pos < pc->sz - 1; j++)
	{
		pc->data[j] = pc->data[j + 1];
	}
	pc->sz--;
	//最后一个元素也就访问不到,这样就不会越界
	printf("删除成功\n");
}


void SearchContact(const contact* pc)
{
	char name[NAME_MAX] = { 0 };
	printf("要查找的人>");
	scanf("%s", name);
	int pos = FindName(pc, name);
	if (pos == -1)
	{
		printf("要查找的人不存在\n");
	}
	printf("%-20s  %-10d  %-5s  %-12s  %-30s\n", "姓名", "年龄", "性别", "电话", "地址");
	printf("%-20s  %-10d  %-5s  %-12s  %-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tel, pc->data[pos].addr);
}




//修改联系人
void menu1()
{
	printf("********************************\n");
	printf("*******1.add     2.del *********\n");
	printf("*******3.search  4.modify*******\n");
	printf("*******5.sort    0.exit   ******\n");
	printf("*******6.print******************\n");
	printf("********************************\n");
}
void ModifyContact(contact* pc)
{
	int input = 0;
	char name[NAME_MAX] = { 0 };
	printf("请输入你要修改的联系人姓名:>");
	scanf("%s", name);

	//查找
	int pos = FindName(pc, name);
	int i = 0;
	if (pos == -1)
	{
		printf("找不到所要查找的联系人\n");
		return;
	}
	//修改
	printf("请输入要修改的具体信息:>\n");
	menu1();
	scanf("%d", &input);
	switch (input)
	{
	case 1:
		printf("请输入新的姓名:>");
		scanf("%s", pc->data[pos].name);
		break;
	case 2:
		printf("请输入新的年龄:>");
		scanf("%d", &pc->data[pos].age);
		break;
	case 3:
		printf("请输入新的性别:>");
		scanf("%s", pc->data[pos].sex);
		break;
	case 4:
		printf("请输入新的电话:>");
		scanf("%s", pc->data[pos].tel);
		break;
	case 5:
		printf("请输入新的地址:>");
		scanf("%s", pc->data[pos].addr);
		break;
	default:
		printf("输入有误,修改失败\n");
		return;
	}
	printf("修改成功\n");
}

test.c

c 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{
	printf("********************************\n");
	printf("*******1.add     2.del *********\n");
	printf("*******3.search  4.modify*******\n");
	printf("*******6.print    0.exit   *****\n");
	printf("********************************\n");
	printf("********************************\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:
			SearchContact(&con);
			break;
		case MODIFY:
			ModifyContact(&con);
			break;
		
		case PRINT:
				PrintContact(&con);
				break;
		case EXIT:
			printf("退出通讯录\n");
			break;

		default:
			printf("选择错误,请重新选择\n");
			break;
				
		}

	} while (input);

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

以上就是我们一个简单通讯录的实现,这就是我们今天的分享,谢谢大家

相关推荐
带多刺的玫瑰42 分钟前
Leecode刷题C语言之统计不是特殊数字的数字数量
java·c语言·算法
爱敲代码的憨仔43 分钟前
《线性代数的本质》
线性代数·算法·决策树
熬夜学编程的小王1 小时前
【C++篇】深度解析 C++ List 容器:底层设计与实现揭秘
开发语言·数据结构·c++·stl·list
yigan_Eins1 小时前
【数论】莫比乌斯函数及其反演
c++·经验分享·算法
阿史大杯茶1 小时前
AtCoder Beginner Contest 381(ABCDEF 题)视频讲解
数据结构·c++·算法
陌小呆^O^1 小时前
Cmakelist.txt之win-c-udp-server
c语言·开发语言·udp
Chris _data1 小时前
二叉树oj题解析
java·数据结构
დ旧言~2 小时前
【高阶数据结构】图论
算法·深度优先·广度优先·宽度优先·推荐算法
时光の尘2 小时前
C语言菜鸟入门·关键字·float以及double的用法
运维·服务器·c语言·开发语言·stm32·单片机·c
张彦峰ZYF2 小时前
投资策略规划最优决策分析
分布式·算法·金融