【C语言】实现一个通讯录(一:静态的实现)

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

实现以下功能:

1. 添加联系人信息

2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人

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

这里我用的是VS2013编译器

首先,我们定义好主函数。

<span style="font-size:14px;">#include"head.h"

int main()
{
	Con con;
	init(&con);
	int num = 0;
	menu();
	while (1)
	{
		printf("请输入你想执行的功能序号:");
		scanf("%d", &num);
		switch (num)
		{
		case 1:
			add_people(&con);
			break;
		case 2:
			delete_people(&con);
			break;
		case 3:
			find_people(&con);
			break;
		case 4:
			alter_people(&con);
			break;
		case 5:
			show_people(&con);
			break;
		case 6:
			clean_people(&con);
			break;
		case 7:
			order_people(&con);
			break;
		case 8:
			exit(0);
			break;
		default:
			printf("指令输入错误!");
			break;
		}
	}

	system("pause");
	return 0;
}
</span>


定义一个头文件,里面包含需要的宏定义,预处理文件,结构体和函数接口。

<span style="font-size:14px;">#define _CRT_SECURE_NO_WARNINGS 1         \\消除scanf不安全的警告

#ifndef _CONTACT_H_                       
#define _CONTACT_H_
#define NAME_MAX 20
#define SEX_MAX 3
#define TEL_MAX 20
#define ADDER_MAX 30
#define PEOPLE_MAX 1000

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

typedef struct people                   //定义通讯录保存的内容结构体
{
	char name[NAME_MAX];
	char sex[SEX_MAX];
	int age;
	char tel[TEL_MAX];
	char adder[ADDER_MAX];
}people;

typedef struct contact                    //定义一个嵌套结构体。
{
	people human[PEOPLE_MAX];
	int count_p;
}Con,*Pcon;

void add_people(Pcon pcon);           //函数接口,实现增加联系人功能
int find_people(Pcon pcon);          //函数接口,实现查找联系人功能
void delete_people(Pcon pcon);       //函数接口,实现删除联系人功能
void alter_people(Pcon pcon);        //函数接口,实现修改联系人信息功能
void show_people(Pcon pcon);         //函数接口,实现显示所有联系人功能
void clean_people(Pcon pcon);           //函数接口, 实现清空联系人功能
void order_people(Pcon pcon);           //函数接口,实现以名字对联系人进行排序功能。
void init(Pcon pcon);                    //初始化结构体
void menu();                             //实现菜单功能
#endif</span>
实现函数功能:

<span style="font-size:14px;">#include"head.h"


void menu()
{
	printf("*******************欢迎使用通讯录2.0   ***************\n");
	printf("                   1.添加联系人信息      \n");
	printf("                   2.删除指定联系人信息  \n");
	printf("                   3.查找指定联系人信息  \n");
	printf("                   4.修改指定联系人信息  \n");
	printf("                   5.显示所有联系人信息  \n");
	printf("                   6.清空所有联系人     \n");
	printf("                   7.以名字排序所有联系人\n");
	printf("                   8.退出\n");
	printf("******************************************************\n");
}

void print(Pcon pcon,int i)        //打印联系人信息
{
	printf("|  姓名  |  性别  |  年龄  |    电话    |      住址     | \n");
	printf("|  %4s  |  %2s  |  %d  |  %6s  |  %6s  |\n", pcon->human[i].name, pcon->human[i].sex, pcon->human[i].age,
		pcon->human[i].tel, pcon->human[i].adder);
	
}

void add_people(Pcon pcon)
{
	if (pcon->count_p == PEOPLE_MAX)    //判断是否已满
	{
		printf("通讯录已满!");
	}
	else
	{
		printf("请输入添加联系人的姓名,性别,年龄,电话,住址:\n");
		scanf("%s", pcon->human[pcon->count_p].name);
		scanf("%s", pcon->human[pcon->count_p].sex);
		scanf("%d", &pcon->human[pcon->count_p].age);
		scanf("%s", pcon->human[pcon->count_p].tel);
		scanf("%s", pcon->human[pcon->count_p].adder);
		print(pcon, pcon->count_p);
		(pcon->count_p)++;
	}
}

int find_people(Pcon pcon)      
{
	char name[NAME_MAX];     
	int i = 0;
	printf("请输入姓名:");
	scanf("%s", name);
	for (i = 0; i < pcon->count_p; i++)
	{
		if (strcmp(pcon->human[i].name, name) == 0) 
		{
			print(pcon,i);
			return i;                  //若输入的姓名与联系人中的一个姓名相符,则返回该联系人的位置
		}
	}
	printf("不存在该联系人\n");
	return -1;
}

void delete_people(Pcon pcon)
{
	int i = 0;
	int ret = find_people(pcon);
	if (ret != -1)
	{
		for (i = ret; i < pcon->count_p; i++)
		{
			pcon->human[i] = pcon->human[i + 1];     //采用移位删除法删除。
		}
		pcon->count_p--;
		printf("删除成功!\n");
		
	}
	else
		printf("不存在该联系人!\n");
	
}

void alter_people(Pcon pcon)
{
	int ret = find_people(pcon);     //接收指定联系人位置
	if (ret != -1)
	{
		printf("请重新输入该联系人信息:\n");
		scanf("%s", pcon->human[ret].name);
		scanf("%s", pcon->human[ret].sex);
		scanf("%d", &pcon->human[ret].age);
		scanf("%s", pcon->human[ret].tel);
		scanf("%s", pcon->human[ret].adder);
		print(pcon,ret);
		printf("修改成功!\n");

	}
}

void show_people(Pcon pcon)
{
	int i = 0;
	for (i = 0; i < pcon->count_p; i++)  //循环打印全部联系人
	{
		print(pcon,i);
	}
}

void clean_people(Pcon pcon)         //将人数置成0,即清空联系人
{
	pcon->count_p = 0;
	printf("成功清空!");
}

void order_people(Pcon pcon)
{
	int i = 0;
	for (i = 0; i < (pcon->count_p) - 1; i++)    //这里采用冒泡排序
	{
		for (int j = 0; j<(pcon->count_p )- 1 - i; j++)
		{
			int min = 0;
			if (strcmp(pcon->human[j].name, pcon->human[j + 1].name)>0)
			{
				people temp = pcon->human[j];
				pcon->human[j] = pcon->human[j + 1];
				pcon->human[j + 1] = temp;

			}
		}
	}
	printf("排序完成\n");
	show_people(pcon);
}



void init (Pcon pcon)   //对结构体进行初始化。
{
	pcon->count_p = 0;
}
</span>

这是静态的实现这个通讯录。

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值