IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 用c语言简单实现通讯录(详解和具体代码) -> 正文阅读

[C++知识库]用c语言简单实现通讯录(详解和具体代码)

前言

一、明确通讯录的功能

1.查找通讯录上的姓名、性别、电话和住址

2.可以增加、删除或修改相关信息

二、如何实现通讯录的功能

1.使用struct函数

2.实现通讯录的步骤

(1)初始化通讯录并打印目录

(2)实现增加信息与展示通讯录

(3)实现查询、删减与修改通讯录

(4)实现清除所有联系人

(5)实现按名字排序

三、具体实现代码展示

前言

通讯录是我们用来找寻相关人信息的一种手段,我们可以通过它找到我们想要找到的人的各种信息,类似于姓名、性别、电话号码和住址等等,它也可以用于存储我们想要存储人的信息,对我们的帮助不小。

一、实现步骤

1.使用struct函数初始化通讯录并打印目录

注:

这里我们需要用到传址调用,因为如果用传值调用不能对通讯录进行修改(在函数传参的时候,传值调用产生形参,形参是实参的一份临时拷贝,对形参的修改并不能改变实参;传址调用是形参和实参公用一块地址,对形参的修改可以影响到实参)。

创建一个struct函数保存中每个人的信息,再创建一个函数实现真正的通讯录(其中sz用来计算通讯录中有多少份信息)。

这里我们使用memset函数来初始化我们的通讯录。

struct peoinfor//每个人的信息
{
	char name[MAX_NAME];
	char sex[MAX_SEX];
	int age;
	char tele[MAX_TELE];
	char addr[MAX_ADDR];
};

struct Contacts
{
	struct peoinfor data[1000];
	int sz;

};
//创建通讯录
	struct Contacts con;
//对通讯录进行初始化
void init_contacts(struct Contacts *pc)
{
	assert(pc);

	pc->sz = 0;
	memset(pc->data, 0, MAX * sizeof(struct peoinfor));
}
void menu()
{
	printf("***************************\n");
	printf("*****1.Add    2.del   *****\n");
	printf("*****3.search 4.modify*****\n");
	printf("*****5.show   6.clear *****\n");
	printf("*****7.sort   0.exit  *****\n");
	printf("***************************\n");

}

2.实现增加和展示

注:

这里我们可以使用assert函数来保证这个函数指针不为空指针(及野指针)。

这里我们采用的是左对齐的方式进行打印,中间包含水平制表符来保证我们打印出来的通讯录能够很清晰的找到我们需要的信息。

void Add_contacts(struct Contacts *pc)
{
	assert(pc);

	if (pc->sz == MAX)
	{
		printf("通讯录已满,无法添加数据\n");
		return;
	 }
	printf("请输入要增加人的名字:>");
	scanf("%s", pc->data[pc->sz].name);
	printf("请输入要增加人的性别:>");
	scanf("%s", pc->data[pc->sz].sex);
	printf("请输入要增加人的年龄:>");
	scanf("%d", &(pc->data[pc->sz].age));
	printf("请输入要增加人的电话:>");
	scanf("%s", pc->data[pc->sz].tele);
	printf("请输入要增加人的地址:>");
	scanf("%s", pc->data[pc->sz].addr);
	pc->sz++;
	printf("已成功添加联系人\n");
}
//展示通讯录中人的信息
void Show_contacts(const struct Contacts* pc)
{
	assert(pc);
	int i = 0;
	printf("%-20s\t%-6s\t%-5s\t%-13s\t%-30s\t\n", "性名", "性别", "年龄", "电话", "住址");
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-20s\t%-6s\t%-5d\t%-13s\t%-30s\t\n", pc->data[i].name,
	          pc->data[i].sex,
              pc->data[i].age, 
			  pc->data[i].tele, 
	          pc->data[i].addr);
	}
}

?3.实现删减和修改通讯录

在实现删减之前我们需要查找该联系人是否在我们创建的通讯录中保存,这里我们用循环并用strcmp函数对两个字符串进行比较,用ret进行接收,用-1来表示该联系人不存在,其余返回i表示存在。这里我们使用static来修饰有返回值的函数,保证其私密性及只能在该文件夹中使用,在其它文件中查询不到。

static int Findbyname(char name[], struct Contacts* pc)
{
	for (int i = 0; i < pc->sz; i++)
	{
		if (0 == strcmp(pc->data[i].name, name))
		{
			return i;
		}

	}
	return -1;
}
//删除通讯录中人的信息
void del_contacts(struct Contacts* pc)
{
	assert(pc);
	char name[MAX_NAME];
	printf("请输入要删除人的姓名:>");
	scanf("%s", name);
	int ret = Findbyname(name, pc);
	if (-1 == ret)
	{
		printf("没有查询到要删除的人的信息\n");
	}
	else
	{
		int j = 0;
		for (j = ret; j < pc->sz; j++)
		{
			pc->data[j] = pc->data[j + 1];
			pc->sz--;
		}
	}
}
//查找通讯录中人的信息
void search_contacts(struct Contacts* pc)
{
	assert(pc);

	char name[MAX_NAME];
	printf("请输入要查找人的姓名\n");
	scanf("%s", name);
	int ret = Findbyname(name, pc);
	if (-1 == ret)
	{
		printf("没有查询到相关人的信息\n");
	}
	else
	{
		printf("%-20s\t%-6s\t%-5d\t%-13s\t%-30s\t\n", pc->data[ret].name,
			pc->data[ret].sex,
			pc->data[ret].age,
			pc->data[ret].tele,
			pc->data[ret].addr);
		printf("查询成功\n");
	}
}
//修改通讯录中人的信息
void modify_contacts(struct Contacts* pc)
{
	assert(pc);

	char name[MAX_NAME];

	printf("请输入要修改的人的姓名:>");
	scanf("%s", name);
	int ret = Findbyname(name, pc);
	if (-1 == ret)
	{
		printf("没有查询到相关人的信息\n");
	}
	else
	{
		printf("请输入名字:>");
		scanf("%s", pc->data[ret].name);
		printf("请输入性别:>");
		scanf("%s", pc->data[ret].sex);
		printf("请输入年龄:>");
		scanf("%d", &(pc->data[ret].age));
		printf("请输入电话:>");
		scanf("%s", pc->data[ret].tele);
		printf("请输入地址:>");
		scanf("%s", pc->data[ret].addr);

		printf("修改成功\n");
	}
}

4.实现清除所有联系人

这里类似于对函数进行初始化。

//清空所有联系人
void clear_contacts(struct Contacts* pc)
{
	assert(pc);
    
	pc->sz = 0;
	memset(pc->data, 0, MAX * sizeof(struct peoinfor));
}

int CmpByName(const void* e1, const void* e2)
{
	return strcmp(((struct peoinfor*)e1)->name, ((struct peoinfor*)e2)->name);
}

5.实现按名字排序

这里使用qsort函数对通讯录中的信息进行快速排序

创建一个函数指针

将两个指针作为参数(均转换为常量 void*)。该函数通过返回(以稳定和传递的方式)来定义元素的顺序:

返回值意义
<0指向 的元素位于 指向 的元素之前p1p2
0指向 的元素等效于 指向 的元素p1p2
>0指向 的元素在 指向 的元素之后p1p2

int CmpByName(const void* e1, const void* e2)
{
	return strcmp(((struct peoinfor*)e1)->name, ((struct peoinfor*)e2)->name);
}

//按照名字来排序
void sort_contacts(struct Contacts* pc)
{
	qsort(pc->data, pc->sz, sizeof(struct peoinfor), CmpByName);
}

二、具体代码展示

1.contacts.c文件

#define _CRT_SECURE_NO_WARNINGS 1

#include "contacts.h"

//对通讯录进行初始化
void init_contacts(struct Contacts *pc)
{
	assert(pc);

	pc->sz = 0;
	memset(pc->data, 0, MAX * sizeof(struct peoinfor));
}
//在通讯录中增加一个人的信息
void Add_contacts(struct Contacts *pc)
{
	assert(pc);

	if (pc->sz == MAX)
	{
		printf("通讯录已满,无法添加数据\n");
		return;
	 }
	printf("请输入要增加人的名字:>");
	scanf("%s", pc->data[pc->sz].name);
	printf("请输入要增加人的性别:>");
	scanf("%s", pc->data[pc->sz].sex);
	printf("请输入要增加人的年龄:>");
	scanf("%d", &(pc->data[pc->sz].age));
	printf("请输入要增加人的电话:>");
	scanf("%s", pc->data[pc->sz].tele);
	printf("请输入要增加人的地址:>");
	scanf("%s", pc->data[pc->sz].addr);
	pc->sz++;
	printf("已成功添加联系人\n");
}
//展示通讯录中人的信息
void Show_contacts(const struct Contacts* pc)
{
	assert(pc);
	int i = 0;
	printf("%-20s\t%-6s\t%-5s\t%-13s\t%-30s\t\n", "性名", "性别", "年龄", "电话", "住址");
	for (i = 0; i < pc->sz; i++)
	{
		printf("%-20s\t%-6s\t%-5d\t%-13s\t%-30s\t\n", pc->data[i].name,
	          pc->data[i].sex,
              pc->data[i].age, 
			  pc->data[i].tele, 
	          pc->data[i].addr);
	}
}

static int Findbyname(char name[], struct Contacts* pc)
{
	for (int i = 0; i < pc->sz; i++)
	{
		if (0 == strcmp(pc->data[i].name, name))
		{
			return i;
		}

	}
	return -1;
}
//删除通讯录中人的信息
void del_contacts(struct Contacts* pc)
{
	assert(pc);
	char name[MAX_NAME];
	printf("请输入要删除人的姓名:>");
	scanf("%s", name);
	int ret = Findbyname(name, pc);
	if (-1 == ret)
	{
		printf("没有查询到要删除的人的信息\n");
	}
	else
	{
		int j = 0;
		for (j = ret; j < pc->sz; j++)
		{
			pc->data[j] = pc->data[j + 1];
			pc->sz--;
		}
	}
}
//查找通讯录中人的信息
void search_contacts(struct Contacts* pc)
{
	assert(pc);

	char name[MAX_NAME];
	printf("请输入要查找人的姓名\n");
	scanf("%s", name);
	int ret = Findbyname(name, pc);
	if (-1 == ret)
	{
		printf("没有查询到相关人的信息\n");
	}
	else
	{
		printf("%-20s\t%-6s\t%-5d\t%-13s\t%-30s\t\n", pc->data[ret].name,
			pc->data[ret].sex,
			pc->data[ret].age,
			pc->data[ret].tele,
			pc->data[ret].addr);
		printf("查询成功\n");
	}
}
//修改通讯录中人的信息
void modify_contacts(struct Contacts* pc)
{
	assert(pc);

	char name[MAX_NAME];

	printf("请输入要修改的人的姓名:>");
	scanf("%s", name);
	int ret = Findbyname(name, pc);
	if (-1 == ret)
	{
		printf("没有查询到相关人的信息\n");
	}
	else
	{
		printf("请输入名字:>");
		scanf("%s", pc->data[ret].name);
		printf("请输入性别:>");
		scanf("%s", pc->data[ret].sex);
		printf("请输入年龄:>");
		scanf("%d", &(pc->data[ret].age));
		printf("请输入电话:>");
		scanf("%s", pc->data[ret].tele);
		printf("请输入地址:>");
		scanf("%s", pc->data[ret].addr);

		printf("修改成功\n");
	}
}
//清空所有联系人
void clear_contacts(struct Contacts* pc)
{
	assert(pc);
    
	pc->sz = 0;
	memset(pc->data, 0, MAX * sizeof(struct peoinfor));
}

int CmpByName(const void* e1, const void* e2)
{
	return strcmp(((struct peoinfor*)e1)->name, ((struct peoinfor*)e2)->name);
}

//按照名字来排序
void sort_contacts(struct Contacts* pc)
{
	qsort(pc->data, pc->sz, sizeof(struct peoinfor), CmpByName);
}



2.contacts.h文件

#pragma once
#include <stdio.h>
#include <string.h>
#include <assert.h>
#include <Windows.h>
#define MAX 1000
#define MAX_NAME 20
#define MAX_SEX 6
#define MAX_TELE 13
#define MAX_ADDR 30


struct peoinfor//每个人的信息
{
	char name[MAX_NAME];
	char sex[MAX_SEX];
	int age;
	char tele[MAX_TELE];
	char addr[MAX_ADDR];
};

struct Contacts
{
	struct peoinfor data[1000];
	int sz;

};
//初始化通讯录
void init_contacts(struct Contacts* pc);

//增加通讯录中人的信息
void Add_contacts(struct Contacts* pc);

//展示通讯录中人的信息
void Show_contacts(struct Contacts* pc);

//删除通讯录中指定人的信息
void del_contacts(struct Contacts* pc);

//查找通讯录中人的信息
void search_contacts(struct Contacts* pc);

//修改通讯录中人的信息
void modify_contacts(struct Contacts* pc);

//清空通讯录中人的信息
void clear_contacts(struct Contacts* pc);

//以名字排序所有联系人
void sort_contacts(struct Contacts* pc);





3.test.c文件

#define _CRT_SECURE_NO_WARNINGS 1
#include "contacts.h"

void menu()
{
	printf("***************************\n");
	printf("*****1.Add    2.del   *****\n");
	printf("*****3.search 4.modify*****\n");
	printf("*****5.show   6.clear *****\n");
	printf("*****7.sort   0.exit  *****\n");
	printf("***************************\n");

}

int main()
{
	int input = 0;
	//创建通讯录
	struct Contacts con;
	//初始化通讯录
	init_contacts(&con);
	do
	{
		menu();
		printf("请选择:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			Add_contacts(&con);
			system("cls");
			break;
		case 2:
			del_contacts(&con);
			system("cls");
			break;
		case 3:
			search_contacts(&con);
			break;
		case 4:
			modify_contacts(&con);
			system("cls");
			break;
		case 5:
			Show_contacts(&con);
			break;
		case 6:
			clear_contacts(&con);
			break;
		case 7:
			sort_contacts(&con);
			system("cls");
			break;

		case 0:
			printf("退出通讯录\n");
			break;
		default:
			break;
		}
	} while (input);
	return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-24 20:38:18  更:2022-09-24 20:42:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 10:42:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码