C语言小项目动态通讯录-创新互联

项目思路

我们要创建一个通讯录,总体来说他是动态增长的,可以节约空间,能够存储数据在文件中

墨玉ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18980820575(备注:SSL证书合作)期待与您的合作!

从小点来分一个通讯录中每个人的各项信息大致包括
1.姓名
2.年龄
3.性别
4.电话号码
5.地址
当然如果需要额外的信息也可以多额外设置函数实现
然后通讯录的功能应该包括:增删查改显示保存这几项基本的功能
大体思路是这样,然后开始实现项目

1.我们创建3个文件 test.c 用来测试,显示整个功能 contact.c 主要用来实现所需函数
contact.h头文件来声明函数

//这个主要是大致的流程和用来测试
test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//总体思路
// 1.创建的每个人信息包括
//       姓名
//       性别
//       年龄
//       电话号码
//       地址
//     
//2.可以增删查改
enum
{EXIT, //0
	ADD, //1  设置枚举只是为了让代码可读性更高
    DEL,
	SEA,
	MOD,
	SHO,
	SOR,

};
void menu()
{//打印一个菜单供选择
	printf("***************1.增添联系人**************************\n");
	printf("***************2.删除联系人**************************\n");
	printf("***************3.查找联系人**************************\n");
	printf("***************4.修改联系人信息**********************\n");
	printf("***************5.查看当前联系人列表******************\n");
	printf("***************6.排列联系人列表**********************\n");
	printf("***************0.保存当前信息并退出通讯录************\n");


}
void test()
{menu();
	int input = 0;
	do
	{printf("请输入你的选择\n");
		scanf("%d", &input);
		switch (input)
		{//实现各个函数
		case ADD:
			AddContact(&con);
			break;
		case DEL:
			DelContact(&con);
			break;
		case SEA:
			SearchContact(&con);
			break;
		case MOD:
			ModifyContact(&con);
			break;
		case SHO:
			ShowContact(&con);
			break;
		case SOR:
			SortContact(&con);
			break;
		case EXIT:
			SaveContact(&con);
			break;
		}
	} while (input);
}
int main()
{//1.要初始化通讯录
	InitContact(&con);
	test();
	return 0;

}



contact.h     //这个主要是声明函数
#define MAX_NAME 15
#define MAX_SEX 8
#define MAX_TELE 15
#define MAX_ARRD 10
#include#include#include#includetypedef struct PeoInfo
{char name[MAX_NAME];
	char sex[MAX_SEX];
	int age;
	char tele[MAX_TELE];
	char addr[MAX_ARRD];
}Peoinfo;

//只创建一个存放学生信息的还不够 我们在应用时还需要知道当前学生的数量
//并且我们创作的这个通讯录应该是动态增长(能够节省空间)的,所以需要设定容量
typedef struct Contact
{Peoinfo* data;//利用指针再去开辟动态空间 也可以利用柔性数组
	int size;
	int capacity;
}Contact;
Contact con;   
void InitContact(Contact* ps);
void AddContact(Contact* ps);
void DelContact(Contact* ps);
void SearchContact(Contact* ps);
void ShowContact(Contact* ps);
void SortContact(Contact* ps);
void SaveContact(Contact* ps);
void Checkfull(Contact* ps);
void ModifyContact(Contact* ps);




contact.c    //主要来实现函数功能
#include "contact.h"    //包含头文件
void InitContact(Contact* ps)
{ps->size = 0;
	ps->capacity = 3;
	ps->data = (Peoinfo*)malloc(sizeof(Peoinfo) * 3);    //初始化
	//读入存在文件中的数据
	FILE* pf = fopen("contact.txt", "rb");
	if (!pf)
	{perror("InitContact");
		return;
	}
	//开始读入   利用fread的返回值 能判断是否读取完整数据
	//需要创建一个变量
	Peoinfo tmp = {0 };
	while (fread(&tmp, sizeof(Peoinfo), 1, pf) != 0)
	{Checkfull(&con);   //每次都要判断读入时容量是否满了
		ps->data[ps->size] = tmp;
		(ps->size)++;
	}
	fclose(pf);
	pf = NULL;
	
}
void  Checkfull(Contact* ps)
{if (ps->size == ps->capacity)
	{//需要扩容
		Peoinfo* ptr = (Peoinfo*)realloc(ps->data,sizeof(Peoinfo) * (ps->size + 2));//扩充两个人
		if (ptr)
		{	ps->data = ptr;
			(ps->capacity) += 2;
		}
	}
	//如果没有满员,则不需要做任何事
}
void AddContact(Contact* ps)
{//添加之前要检查当前容量是否已经满了
	Checkfull(&con);
	//增加联系人的各项信息
	printf("请输入联系人的姓名\n");
	scanf("%s", ps->data[ps->size].name);
	printf("请输入联系人的年龄\n");
	scanf("%d", &(ps->data[ps->size].age));
	printf("请输入联系人的性别\n");
	scanf("%s", ps->data[ps->size].sex);
	printf("请输入联系人的电话号码\n");
	scanf("%s", ps->data[ps->size].tele);
	printf("请输入联系人的地址\n");
	scanf("%s", ps->data[ps->size].addr);
	printf("添加成功\n");
	(ps->size)++;
}
int Search(char* names)
{int i = 0;     //遍历
	for (i = 0; i< con.size; i++)
	{if (strcmp(con.data[i].name, names) == 0)

		{	return i;
		}
	}
	return -1;
}
void SearchContact(Contact* ps)
{//再设置一个函数查找
	//如果找到了就返回下标,如果没有找到就返回-1
	printf("请输入你要查找的联系人的姓名\n");
	char names[MAX_NAME];
	scanf("%s", names);
	int ret = Search(names);
	if (ret == -1)
	{printf("找不到此人\n");
	}
	else
	{//要把这个人的信息全部都打印出来所以我们先实现show函数
		printf("%-15s\t%-5s\t%-5d\t%-15s\t%-10s\n",
			ps->data[ret].name,
			ps->data[ret].sex,
			ps->data[ret].age,
			ps->data[ret].tele,
			ps->data[ret].addr);
	}

}






void DelContact(Contact* ps)
{printf("请输入你需要删除的联系人的名字\n");
	char names[MAX_NAME];
	scanf("%s", names);
	//首先需要查找到联系人,那我们优先完成查找函数
	int ret = Search(names);
	if (ret == -1)
	{printf("找不到你要删除的这个联系人\n");
	}
	else
	{//删除思路:把删除人之后的每一位联系人向前移一位,最后再把size减一即可
		int i = 0;
		for (i = ret; i< ps->size-1; i++)
		{	ps->data[i] = ps->data[i + 1];
		}
		(ps->size)--;
		printf("删除成功\n");
		
	}
}

void ShowContact(Contact* ps)
{//开始时需要判断一下 是否有人
	if (ps->size == 0)
	{printf("目前还没有联系人\n");
	}
	//左对齐
	else
	{printf("%-15s\t%-5s\t%-5s\t%-15s\t%-10s\n", "姓名", "年龄", "性别", "电话", "地址");
		for (int i = 0; i< ps->size; i++)
		{	//打印每个人的各项信息
			printf("%-15s\t%-5s\t%-5d\t%-15s\t%-10s\n",
				ps->data[i].name,
				ps->data[i].sex,
				ps->data[i].age,
				ps->data[i].tele,
				ps->data[i].addr);
		}
	}
}
int com_by_name(void* e1, void* e2)
{return strcmp((char*)e1, (char*)e2);
}
void SortContact(Contact* ps)
{//利用qsort函数来排序   我上一篇文章有详细的讲解
	//我们这里就按姓名分类,其他也是同理可以得到
	qsort(ps->data, ps->size, sizeof(Peoinfo), com_by_name);
	printf("排序成功\n");
	ShowContact(ps);
}
void SaveContact(Contact* ps)
{int i = 0;
	//写入一个文件中
	FILE* pf = fopen("contact.txt", "wb");//以二进制的形式写入 
	if (!pf)
	{perror("SaveContact");//错误时,能够打印错误的信息
		return;
	}
	else
	{for (i = 0; i< ps->size; i++)
		{	fwrite(&(ps->data[i]), sizeof(Peoinfo), 1, pf);
		}
	}
	fclose(pf);
	pf = NULL;

}
void ModifyContact(Contact* ps)
{printf("请输入你要修改的联系人姓名\n");
	char names[MAX_NAME];
	scanf("%s", names);
	int ret = Search(names);
	if (ret == -1)
	{printf("找不到你要修改的联系人\n");
	}
	else
	{printf("请输入联系人的姓名\n");
		scanf("%s", ps->data[ret].name);
		printf("请输入联系人的年龄\n");
		scanf("%d", &(ps->data[ret].age));
		printf("请输入联系人的性别\n");
		scanf("%s", ps->data[ret].sex);
		printf("请输入联系人的电话号码\n");
		scanf("%s", ps->data[ret].tele);
		printf("请输入联系人的地址\n");
		scanf("%s", ps->data[ret].addr);
		printf("修改成功\n");
}

到这里项目就完成了,虽然看起来有很多行,但是找清楚思路后很好写

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


当前名称:C语言小项目动态通讯录-创新互联
链接分享:http://scyanting.com/article/dojidd.html