C语言实现一个通讯录

实现一个通讯录; 
通讯录可以用来存储1000个人的信息,每个人的信息包括: 
姓名、性别、年龄、电话、住址 

提供方法: 
1. 添加联系人信息 
2. 删除指定联系人信息 
3. 查找指定联系人信息 
4. 修改指定联系人信息 
5. 显示所有联系人信息 
6. 清空所有联系人 

7. 以名字排序所有联系人

(1)头文件contact.h

#ifndef __CONTACT 
#define __CONTACT 

#endif//条件编译 
#pragma warning (disable:4996)

#include<stdio.h> 
#include<stdlib.h> 
#include<string.h> 
#include<assert.h> 
#define N 1000 

struct contact
{
	char name[30];
	char gender[10];
	int age;
	int telephone;
	char address[100];
};
void menu();
void show(struct contact *p, int len);
void Add_linkman(struct contact *p, int len, int flag);
void Delete_linkman(struct contact *p, int d_number, int len);
void Find_member(struct contact *p, int d_number, int len);
void empty(struct contact *p);
void Modify(struct contact *p, int M_member);
void cmp(const void *a, const void *b);
void sort(struct contact *p, int len);

(2)函数具体实现contact.c

#include"test.h" 
void menu()
{
	printf("##################################\n");
	printf("##### 1.增加联系人信息       #####\n");
	printf("##### 2.删除联系人信息       #####\n");
	printf("##### 3.查找指定联系人信息   #####\n");
	printf("##### 4.修改指定联系人信息   #####\n");
	printf("##### 5.显示所有联系人信息   #####\n");
	printf("##### 6.清空所有联系人       #####\n");
	printf("##### 7.以名字排序所有联系人 #####\n");
	printf("##### 0.退出!               #####\n");
	printf("##################################\n");
}
void show(struct contact *p, int len)
{
	assert(p);
	int i = 0;
	for (i = 0; i < len; i++)
	{
		printf("name:%s gender:%s age:%d telephone:%d address:%s", \
			p[i].name, p[i].gender, p[i].age, p[i].telephone, p[i].address);
		printf("\n");
	}
}
void Add_linkman(struct contact *p, int len, int flag)
{
	assert(p);
	int i = 0;
	for (i = flag; i < len; i++)
	{
		printf("请输入姓名:");
		scanf("%s", &p[i].name);
		printf("请输入姓别:");
		scanf("%s", &p[i].gender);
		printf("请输入年龄:");
		scanf("%d", &p[i].age);
		printf("请输入电话:");
		scanf("%d", &p[i].telephone);
		printf("请输入地址:");
		scanf("%s", &p[i].address);
	}
}
void Delete_linkman(struct contact *p, int d_number, int len)
{

	assert(p);
	int i = 0;
	for (i = d_number - 1; i < len - 1; i++)
	{
		p[i] = p[i + 1];

	}
}
void Find_member(struct contact *p, int d_number, int len)
{
	assert(p);
	if (d_number - 1 >= 0 || d_number - 1<len)
	{
		printf("name:%s gender:%s age:%d telephone:%d address:%s", \
			p[d_number].name, p[d_number].gender, p[d_number].age, p[d_number].telephone, p[d_number].address);
		printf("\n");
	}
	else
	{
		printf("不存在该联系人:");
		return;
	}

}
void empty(struct contact *p)
{
	assert(p);
	int i = 0;
	for (i = 0; i <1000; i++)
	{
		memset(p + i, 0, sizeof(struct contact));
	}

}
void Modify(struct contact *p, int M_member)
{
	assert(p);
	printf("修改之前联系人的信息为:");
	printf("\n");
	printf("name:%s gender:%s age:%d telephone:%d address:%s", \
		p[M_member - 1].name, p[M_member - 1].gender, p[M_member - 1].age, p[M_member - 1].telephone, p[M_member - 1].address);
	printf("\n");
	printf("请输入要修改的信息:");
	printf("请输入姓名:");
	scanf("%s", &p[M_member - 1].name);
	printf("请输入姓别:");
	scanf("%s", &p[M_member - 1].gender);
	printf("请输入年龄:");
	scanf("%d", &p[M_member - 1].age);
	printf("请输入电话:");
	scanf("%d", &p[M_member - 1].telephone);
	printf("请输入地址:");
	scanf("%s", &p[M_member - 1].address);

}
void cmp(const void *a, const void *b)
{

	struct contact *aa = (struct contact *)a;
	struct contact *bb = (struct contact *)b;
	if (aa->name != bb->name)
		return(strcmp((aa->name), (bb->name)));

}
void sort(struct contact *p, int len)
{
	assert(p);
	qsort(p, len, sizeof(struct contact), cmp);

}

(3)main函数

#include"test.h" 
int main()
{
	int num = 0;
	struct contact student[N];
	int len = 0;
	int flag = 0;//定义一个标志位来标志结构体数组中每个结构体的位置 
	int total = N;
	int delete_number = 0;
	menu();
	while (1)
	{
		printf("请输入数字进行选择:");
		scanf("%d", &num);

		switch (num){
		case 1:{
				   printf("请添加len个学生的信息:");
				   scanf("%d", &len);
				   Add_linkman(student, len + flag, flag);
				   flag = flag + len;
		}break;

		case 2:{
				   printf("请输入要删除的第i个学生的信息:");
				   scanf("%d", &delete_number);
				   Delete_linkman(student, delete_number, len + flag);
				   flag = flag - 1;
		}break;

		case 3:{
				   int Find_number = 0;
				   printf("请输入要查找的第i个学生的信息:");
				   scanf("%d", &Find_number);
				   Find_member(student, delete_number, len + flag);
		}break;

		case 4:{
				   printf("请输入要修改的的第i个学生的信息:");
				   int M_member = 0;
				   scanf("%d", &M_member);
				   Modify(student, M_member);
		}break;
		
		case 5:{
				   printf("打印所有联系人的信息:\n");
				   show(student, flag);
		}break;

		case 6:{
				   printf("清空所有联系人:");
				   empty(student);
		}break;

		case 7:{
				   printf("根据名字排序所有联系人:\n");
				   sort(student, len + flag);
		}break;

		case 0:{
				   exit(1);
		}

		default:printf("enter error data!!");

		}
	}
	system("pause");
	return 0;

}




猜你喜欢

转载自blog.csdn.net/qq_39026129/article/details/80503070