C语言实现通讯录的详细代码

目录
  • (一)实现思路
    • 1.通讯录功能
    • 2.模块化实现各方面的功能
    • 3.代码实现
  • (二)源代码
    • A.test.c
    • B.Contact.h
    • C.Contact.c

(一)实现思路

1.通讯录功能

添加好友,删除好友,查找好友,修改好友信息,对好友进行排序

2.模块化实现各方面的功能

a. test.c

测试通讯录功能

b. Contact.c

实现通讯录功能

c. Contact.h

包含通讯录实现的头文件

3.代码实现

(二)源代码

A.test.c

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

void menu()
{
	printf("*******************************\n");
	printf("***  1.Add         2.Del    ***\n");
	printf("***  3.Search      4.Modify ***\n");
	printf("***  5.Show        6.Sort   ***\n");
	printf("***  7.Help        8.About0 ***\n");
	printf("***  0.Exit                 ***\n");
	printf("*******************************\n");
}

int main()
{

	int input = 0;
	//创建通讯录
	int size = 0;
	struct Contact con;//一个结构体里包含1000个人的信息和size;
	//size表示的是该通讯录里现在的好友数
	//初始化通讯录
	InitContact(&con);//使size的初始值,以及好友信息初始化为0;
	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 Show:
			ShowContact(&con);
			break;

			//好友排序
		case Sort:
			SortContact(&con);
			break;

			//退出
		case Exit:
			printf("退出通讯录!");
			break;

			//通讯录的使用以及帮助
		case Help:
			HelpContact();
			break;

			//关于通讯录
		case About:
			AboutContact();
			break;

			//选择错误
		default:
			printf("选择错误!");
			break;
		}

	} while (input);
	return 0;
}

B.Contact.h

#define _CRT_SECURE_NO_WARNINGS 1
#define Max 1000
#define Max_name 20
#define Max_sex 5
#define Max_tele 12
#define Max_addr 30

enum Option
{
	Exit,
	Add,
	Del,
	Search,
	Modify,
	Show,
	Sort,
	Help,
	About

};

//创建一个结构体来存放通讯录中要存放的信息
struct PeoInfo
{
	char name[Max_name];
	int age;
	char sex[Max_sex];
	char tele[Max_tele];
	char addr[Max_addr];
};

//通讯录类型
struct Contact
{
	struct PeoInfo data[Max];//存放一个信息,包括好友姓名,年龄,性别,电话,地址
	int size;//记录当前已经有的元素个数
	//存入一个好友,size加1,表示通讯录人数增加一个
};

//声明函数
//1.对通讯录进行初始化
void InitContact(struct Contact* ps);

//增加好友信息
void AddContact(struct Contact* ps);

//删除好友
void DelContact(struct Contact* ps);

//查找指定姓名的好友
void SearchContact(struct Contact* ps);

//显示好友信息
void ShowContact(const struct Contact* ps);

//修改好友信息
void ModifyContact( struct Contact* ps);

//按名字首字母对通讯录的好友进行排序
void SortContact( struct Contact* ps);

//帮助使用通讯录
void HelpContact();

//关于通讯录
void AboutContact();

C.Contact.c

#define _CRT_SECURE_NO_WARNINGS 1

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

//初始化通讯录
void InitContact(struct Contact* ps)
{
	memset(ps->data, 0, sizeof(ps->data));
	ps->size = 0;//设置通讯录最初只有0个元素
}

//帮助使用通讯录
void HelpContact()
{
	printf("各按键的使用:\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 AboutContact()
{
	printf("通讯录一般指在日常生活中用笔记录,也在手机,电脑,电子字典等电子产品中拥有这个功能。\n");
}

//增加好友的电话,信息
void AddContact(struct Contact* ps)
{
	if (ps->size == Max)
	{
		printf("通讯录已满,无法增加!\n");
	}
	else
	{
		printf("请输入姓名:");
		scanf("%s", ps->data[ps->size].name);
		//除了年龄,其他都是数组,直接用数组名
		printf("请输入年龄:");
		scanf("%d", &(ps->data[ps->size].age));
		//年龄不是数组,则需要&
		printf("请输入性别:");
		scanf("%s", ps->data[ps->size].sex);
		printf("请输入电话:");
		scanf("%s", ps->data[ps->size].tele);
		printf("请输入地址:");
		scanf("%s", ps->data[ps->size].addr);
		ps->size++;
		//添加成功一个1好友,size加1,;
		printf("添加成功!\n");
	}

}

//在删除,查找,修改的函数中均涉及查找到该好友才能进行
//为了避免冗余,我们把查找的这个环节从函数中抽离出来
//在函数中直接使用,就不会显得重复

static int Find_by_name(struct Contact* ps, char name[Max_name])
{
	int i;
	for (i = 0; i < ps->size; i++)
	{
		//将要查找的好友姓名与通讯录中的好友进行比较
		if (0 == strcmp(ps->data[i].name, name))
		{
			//若找到,返回其下标
			return i;
		}
	}
	//若都循环,比对完了以后还没找到就返回-1
	return -1;
}

//删除好友信息
void DelContact(struct Contact* ps)
{
	int  j;
	char name[Max_name];
	printf("请输入删除好友的名字:");
	scanf("%s", name);
	//1.查找要删除的人的位置
	int pos = Find_by_name(ps, name);
	//调用函数进行查找,若找到,返回下标,若没找到,返回-1;
	//2.删除
	if (pos==-1)
	{
		printf("该好友不存在!\n");
	}
	else
	{
		//删除数据
		for (j = pos; j < ps->size - 1; j++)
		{
			ps->data[j] = ps->data[j + 1];
			//删除数据后,后面的元素位置都改变,向前移动一个位置;
		}
		ps->size--;
		//删除一个好友,size-1.
		printf("删除成功!\n");
	}
}

//查找指定好友信息
void SearchContact(struct Contact* ps)
{
	char name[Max_name];
	printf("输入要查找的好友姓名:");
	scanf("%s", name);
	int pos = Find_by_name(ps, name);
	if (pos ==-1)
	{
		printf("该好友不存在!\n");
	}
	else
	{
		printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");
		printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
			ps->data[pos].name,
			ps->data[pos].age,
			ps->data[pos].sex,
			ps->data[pos].tele,
			ps->data[pos].addr);
	}

}

//修改好友信息
void ModifyContact(struct Contact* ps)
{

	char name[Max_name];
	printf("请输入需要修改信息的好友姓名:");
	scanf("%s", name);
	int pos=Find_by_name(ps, name);
	if (pos == -1)
	{
		printf("该用户不存在!\n");
	}
	else
	{
		printf("请输入姓名:");
		scanf("%s", ps->data[pos].name);
		printf("请输入年龄:");
		scanf("%d", &(ps->data[pos].age));
		printf("请输入性别:");
		scanf("%s", ps->data[pos].sex);
		printf("请输入电话:");
		scanf("%s", ps->data[pos].tele);
		printf("请输入地址:");
		scanf("%s", ps->data[pos].addr);
		printf("修改成功!\n");
	}

}

//显示出好友的基本信息
void ShowContact(const struct Contact* ps)
{
	if (ps->size == 0)
	{
		printf("通讯录为空!\n");
	}
	else
	{
		int i = 0;
		printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");
		for (i = 0; i < ps->size; i++)
		{
			printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
				ps->data[i].name,
				ps->data[i].age,
				ps->data[i].sex,
				ps->data[i].tele,
				ps->data[i].addr);

		}
	}
}

//按照名字的首字母进行排序

int cmp_stu_by_name(const void* e1, const void* e2)
{
	return (strcmp(((struct Contact*)e1)->data->name, ((struct Contact*)e2)->data->name));
}

//我们用qsort()函数对我们的好友按照名字首字母进行排序
void SortContact( struct Contact* ps)
{
	qsort(ps->data, ps->size, sizeof(ps->data[0]), cmp_stu_by_name);
	printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");
	int i;
	for (i = 0; i < ps->size; i++)
	{
		printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
			ps->data[i].name,
			ps->data[i].age,
			ps->data[i].sex,
			ps->data[i].tele,
			ps->data[i].addr);
	}
}

到此这篇关于C语言实现通讯录的详细代码的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C语言实现个人通讯录管理系统

    如何用c语言制作简易的个人通讯录管理系统?想必这是每一位初步学习c语言的同学需要解决的一个大问题.如何将这些数据类型不完全相同的数据元素存储并访问呢?采用结构体便能轻松解决这个问题! #include<stdio.h> #include<string.h> #include<stdlib.h> #include<windows.h> struct stu //第一部分:声明结构体类型struct stu { char name[100];//姓名为字符串型

  • C语言实现通讯录小功能

    本文实例为大家分享了C语言实现通讯录功能的具体代码,供大家参考,具体内容如下 头文件contact.h #pragma once #define _CRT_SECURE_NO_WARNINGS 1 //#define max 1000 #define fault 3 #define max_name 20 #define max_telephone 12 #define max_sex 5 #define max_address 30 #include<stdio.h> #include<

  • C语言之通讯录的模拟实现代码

    在C语言学习结束之际,谨以此篇文章来对C语言的学习告一段落. 纲要: 通讯录的静态版本 通讯录的动态版本 通讯录的带文件版本 因为三种实现方法除了储存形式不同,其他都基本相同,所以我们重点论述静态版本的实现,以及它们不同的储存方式. 一.通讯录的静态版本 为什么叫它为静态版本呢,因为在此部分的储存是以数组来储存的,那对于各种各样的信息,我们要拿什么数组来存放它呢?当然是结构体数组了,所以我们来定义一个结构体来表示个人信息: //采用宏的目的是方便日后修改 #define NAME_MAX 20

  • 用C语言实现简易通讯录

    C语言实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括: 姓名.性别.年龄.电话.住址 **提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6. 清空所有联系人 7. 以名字排序所有联系人** 思路分析: 首先我们可以分三个模块来解决这个问题,第一个模块我们需要一个头文件,这个头文件里可以包含一些相应信息,当实现文件和测试文件包含自己定义的头文件时便可以获得一些相关的信息.所以头文件里

  • C语言实现通讯录程序

    本文实例为大家分享了C语言实现通讯录程序的具体代码,供大家参考,具体内容如下 设计要求: 可以存放1000个人的信息,每个人的信息包括姓名.年龄.性别.电话.住址 通讯录功能包括: 1.增加联系人 2.删除指定联系人 3.查找指定联系人 4.修改指定联系人 5.显示所有联系人 6.退出通讯录 思路分析: 首先我们需要创建3个文件,分别是源文件(test.c).通讯录文件(contact.c).通讯录头文件(contact.h),其中头文件用来包含头文件.声名信息.结构体.创建全局变量以及宏. 我

  • C语言实现通讯录的方法(包括静态版本和动态版本)

    目录 1.静态通讯录的实现 实现的方法: 2.动态通讯录的实现 实现的方法: 3.总结 1.静态通讯录的实现 实现的方法: 我们采用的方法就是工程形势,实现将功能和定义以及测试分成三个文件,其中定义放在.h文件,实现和测试放在.c文件当中. (1)contact.h文件的基本实现: #pragma once//防止头文件重复定义 #define NAME_MAX 20 #define SEX_MAX 5 #define TELE_MAX 12 #define ADDR_MAX 30 #defin

  • 详解C语言之实现通讯录

    目录 基本思路和代码实现 其他探讨 总结 基本思路和代码实现 为了代码清晰易读,我们创建一个Main.c源文件用来实现代码的基本逻辑.创建一个Contact.h源文件用于封装实现功能的函数,创建Contact.h头文件用于函数的声明. 首先就是构架代码基本框架,在主函数中实现打印菜单和循环的功能 (这里为了好截图switch里的语句缩进得比较紧凑) 基本逻辑实现后开始考虑创建通讯录,通讯录里会记录人的信息.所以要先能够描述人的信息: 创建表达人的信息的结构体类型,在Contact.h中定义: 而

  • C语言实现简单通讯录功能

    本文实例为大家分享了C语言实现简单通讯录功能的具体代码,供大家参考,具体内容如下 1.存放联系人信息 2.信息:名字+年龄+性别+电话+住址 3.增加联系人 4.删除联系人 5.查找联系人 6.修改联系人 7.排序 test.c源文件代码如下: #define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" void menu() { printf("#####################################\n&

  • C语言实现通讯录管理系统

    本文实例为大家分享了C语言实现通讯录管理系统的具体代码,供大家参考,具体内容如下 工具:Visual C++6.0 说明: 本系统基于C语言实现班级通讯录管理系统,为大一时学习C语言刚入门所做的课程设计.功能包括增.删.查.改等,非常适合初学者练手.通讯录包括的个人信息有姓名.学号.性别.籍贯.政治面貌.手机号.QQ号.宿舍等.主要用到了指针.结构体.遍历链表.文件读取等知识点. 运行效果: 代码: #include<stdio.h> #include<string.h> #inc

  • C语言实现可排序通讯录的示例代码

    目录 1.目的 2.分部流程 1.初始化通讯录 2.添加联系人 3.判断联系人是否存在 4.判断通讯录是否已满 5.判断通讯录是否为空 6.通讯录扩容 7.核心函数 8.查找联系人 9.修改联系人 10.清空通讯录 11.删除联系人 12.显示通讯录 13.比较联系人 14.通讯录排序 3.总代码展示 1.目的 写一个实用型通讯录,它有如下功能: 显示目录 void ShowMenu() { printf("#######################\n"); printf(&qu

  • C语言简易通讯录的实现代码

    本文实例为大家分享了C语言简易通讯录的具体代码,供大家参考,具体内容如下 通讯录的实现: 一.介绍: 运用C语言的数组.指针.结构体等相关知识:实现一个简易的通讯录: 此通讯录的大概内容为: 通讯录可存储1000个人的信息: 每个人的基本信息有:名字+ 年龄+性别 +  电话+ QQ + 地址 此通讯录所具有的功能:增加+ 删除 +  查询 + 修改 +  排序 + 退出 此通讯录在设计时:总共设计了三个文件: contact.h: 类型的声明和函数的声明 contact.c:函数功能的具体实现

随机推荐