天天看点

C语言的简易通讯录

在我们的平常生活中常常会用到电话通讯录,常用的功能有添加联系人,删除,查找,删除,清空,显示,按姓名排序等

现在我们就来实现以下要求的简易通讯录

实现一个通讯录;

通讯录可以用来存储1000个人的信息,每个人的信息包括:

姓名、性别、年龄、电话、住址

提供方法:

1. 添加联系人信息

2. 删除指定联系人信息

3. 查找指定联系人信息

4. 修改指定联系人信息

5. 显示所有联系人信息

6. 清空所有联系人

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

要实现通讯录,就要用到结构体。可以创建两个结构体,一个用来存放数据的,另一个把这些数据存放起来。

相当于先创建一个文件夹用来存放下的小电影,文件夹可以按照国家来创建很多个嘛,然后再把这么多的文件夹放在你的隐藏空间里。这里按照国家起名的文件夹就是第一个结构体,这个隐藏空间就是第二个结构体。隐藏空间肯定要用一个计算存了多少文件夹的计数器,所以第二个结构体要定义一个计数器。

具体的怎么实现直接来看代码,注释里有解释

按模块化来写

test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "Contact.h"

void menu()
{
	printf("***************************************************\n");
	printf("***1、添加联系人信息       2、删除指定联系人信息***\n");
	printf("***3、查找指定联系人信息   4、修改指定联系人信息***\n");
	printf("***5、显示所有联系人信息   6、清空所有联系人    ***\n");
	printf("***7、以名字排序所有联系人 0、exit              ***\n");
	printf("***************************************************\n");
}

enum OP	//用枚举法列出选项,直观
{
	EXIT,
	ADD,
	DEL,
	FIND,
	MOD,
	SHOW,
	EMPTY,
	SORT
};

void test()
{
	int input = 0;
	struct Contact my_con;	//创建一个struct Contact类型的对象
	my_con.sz = 0;	//将计数器清零
	InitContact(&my_con);	//初始化对象
	do
	{
		menu();
		printf("请输入你的选择:>");
		scanf("%d",&input);
		switch (input)
		{
		case ADD:
			add_con(&my_con);
			break;
		case DEL:
			del_con(&my_con);
			break;
		case FIND:
			find_con(&my_con);
			break;
		case MOD:
			modifty_con(&my_con);
			break;
		case SHOW:
			show_con(&my_con);
			break;
		case EMPTY:
			empty_con(&my_con);
			break;
		case SORT:
			sort_con(&my_con);
			break;
		case EXIT:
			printf("退出\n");
			break;
		default:
			printf("选择错误\n");
			break;
		}
	}while(input);

}

int main()
{
	test();
	system("pause");
	return 0;
}
           

Contact.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "Contact.h"

void InitContact(Contact pcon)	//静态初始化
{
	pcon->sz = 0;
	memset(pcon->data,0,sizeof(pcon->data));
}

int add_con(Contact pcon)	//添加数据
{
	if(pcon->sz == MAX)	//派出存满
	{
		printf("通讯录已满\n");
		return -1;
	}
	{
	printf("请输入姓名:>");
	scanf("%s",pcon->data[pcon->sz].name);
	printf("请输入性别:>");
	scanf("%s",pcon->data[pcon->sz].sex);
	printf("请输入年龄:>");
	scanf("%d",&pcon->data[pcon->sz].age);
	printf("请输入电话号码:>");
	scanf("%s",pcon->data[pcon->sz].tel);
	printf("请输入地址:>");
	scanf("%s",pcon->data[pcon->sz].addr);
	printf("添加成功\n");}
	pcon->sz++;		//存一个计数器加1
	return 0;
}

int del_con(Contact pcon)	//要删除的数据
{
	int i = 0;
	int ret = 0;
	if(pcon->sz == 0)	//如果没有数据则返回-1
	{
		printf("通讯录里没有信息\n");
		return 0;
	}
	ret = find_con(pcon);	//先遍历一遍
	if(ret != -1)
	{
		for(i=ret; i<pcon->sz-1; i++);
		{
			pcon->data[i] = pcon->data[i+1];	//删除相当于把后面的数据依次向前覆盖前面的数据
		}
		pcon->sz--;		//删除之后计数器减1
		return 1;
	}
	else 
	{
		printf("没有要删除的人\n");
		return -1;
	}
}

int find_con(Contact pcon)	//查找,为后面的其他选项提供遍历
{
	int i = 0;
	char name[NAME_MAX];
	printf("请输入名字:>");
	scanf("%s",name);
	for(i=0; i<pcon->sz; i++)
	{
		if(strcmp(pcon->data[i].name,name)==0)
		{
			printf("%10s",pcon->data[i].name);
			printf("%4s",pcon->data[i].sex);
			printf("%4d",pcon->data[i].age);
			printf("%12s",pcon->data[i].tel);
			printf("%20s",pcon->data[i].addr);
			printf("\n");
			return i;
		}
	}
	return -1;
}

int modifty_con(Contact pcon)	//要修改的内容
{
	int i = 0;
	int ret = 0;
	if(pcon->sz == 0)	//如果没数据则返回
	{
		printf("没有可修改的数据\n");
		return 0;
	}
	ret = find_con(pcon);	//先在遍历一遍,看有没有要修改的数据
	if(ret != -1)
	{
		printf("请重新输入要改的数据\n");
		printf("请输入姓名:>");
		scanf("%s",pcon->data[pcon->sz].name);
		printf("请输入性别:>");
		scanf("%s",pcon->data[pcon->sz].sex);
		printf("请输入年龄:>");
		scanf("%d",pcon->data[pcon->sz].age);
		printf("请输入电话:>");
		scanf("%s",pcon->data[pcon->sz].tel);
		printf("请输入地址:>");
		scanf("%s",pcon->data[pcon->sz].addr);
		return 1;
	}
	else
	{
		printf("没找到要修改的名字\n");
		return -1;
	}
}

int show_con(Contact pcon)	//将所有信息按存入时间来显示出来
{
	int i = 0;
	for(i=0; i<pcon->sz; i++)	//时间顺序
	{
		printf("%10s",pcon->data[i].name);
		printf("%4s",pcon->data[i].sex);
		printf("%4d",pcon->data[i].age);
		printf("%12s",pcon->data[i].tel);
		printf("%20s",pcon->data[i].addr);
		printf("\n");
	}
	printf("\n");
	return 0;
}

int empty_con(Contact pcon)	//清空数据
{
	pcon->sz = 0;	//只是将要计数器清零,实际数据还在(相当于地址变为起始地址指针)
	return 0;
}

int sort_con(Contact pcon)	//按姓名字母大小排序显示
{
	int tmp = 0;
	int ret = 0;
	int i = 0;
	int j = 0;
	PeoInfo swp ;	//定义另一个PeoInfo的对象
	if(pcon->sz == 0)	//如果列表为空,则返回
	{
		printf("没有可靠的数据\n");
		return 0;
	}
	for(i=0; i<pcon->sz-1; i++)
	{
		for(j=0; j<pcon->sz-i-1; j++)
		{
			if(strcmp(pcon->data[j].name,pcon->data[j+1].name)>0)	//按照名字的大小,按照从小到大冒泡排序
			{
				swp = pcon->data[j];
				pcon->data[j] = pcon->data[j+1];
				pcon->data[j+1] = swp;
			}
		}
	}
	tmp = show_con(pcon);	//将排序后的打印出来
	return 0;
}
           

Contact.h

#ifndef __CONTACT_H__
#define __CONTACT_H__

#define _CRT_SECURE_NO_WARNINGS 1
#include <windows.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#define NAME_MAX 20
#define SEX_MAX 4
#define TEL_MAX 12
#define ADDR_MAX 30
#define MAX 1000

typedef struct PeoInfo	//定义一个存一个数据的结构体
{
	char name[NAME_MAX];
	char sex[SEX_MAX];
	int age;
	char tel[TEL_MAX];
	char addr[ADDR_MAX];
}PeoInfo;

typedef struct Contact	//定义一个能存放1000个类型为PeoInfo类型的结构体
{
	PeoInfo data[MAX];
	int sz;
};

typedef struct Contact *Contact;	//将结构体重命名为一个结构体指针,用来直接指向结构体内容
void InitContact(Contact pcon);
int add_con(Contact pcon);
int del_con(Contact pcon);
int find_con(Contact pcon);
int modifty_con(Contact pcon);
int show_con(Contact pcon);
int empty_con(Contact pcon);
int sort_con(Contact pcon);



#endif //__CONTACT_H__
           
C语言的简易通讯录
C语言的简易通讯录
C语言的简易通讯录
C语言的简易通讯录
C语言的简易通讯录

继续阅读