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++知识库 -> 通讯录Contact -> 正文阅读

[C++知识库]通讯录Contact

利用C语言编写通讯录程序

Utili.h

#ifndef _UTILI_H_
#define _UTILI_H_

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdbool.h>

#endif     /*  _UTILI_H_  */

Contact.h

#ifndef _CONTACT_H_
#define _CONTACT_H_

#include"utili.h"

enum {QUIT,ADD,DEL,FIND,MODIFY,CLEAR,SORT,SHOW};


#define MAX_NAME_SIZE 20
#define MAX_SEX_SIZE 3
#define MAX_TEL_SIZE 12
#define MAX_ADD_SIZE 256

#define MAX_CONTACT_SIZE 256

//定义信息结构
typedef struct PersonInfo
{
	char name[MAX_NAME_SIZE];
	char sex[MAX_SEX_SIZE];
	int age;
	char tel[MAX_TEL_SIZE];
	char add[MAX_ADD_SIZE];
}PersonInfo;

//定义通讯录结构
typedef struct Contact
{
	PersonInfo Cont[MAX_CONTACT_SIZE];
	size_t capacity;
	size_t size;
}Contact;

bool IsEmpty(Contact* pcnt);
bool IsFull(Contact* pcnt);
int FindByName(Contact* pcnt,char name[]);
void InitContact(Contact* pcnt);
void AddContact(Contact* pcnt);
void ShowContact(Contact* pcnt);
void FindContact(Contact* pcnt);
void ModifyContact(Contact* pcnt);
void DelContact(Contact* pcnt);
void ClearContact(Contact* pcnt);
void SortContact(Contact* pcnt);


#endif    /*  _CONTACT_H_  */

Contact.c

#include"contact.h"

void InitContact(Contact* pcnt)
{
	memset(pcnt->Cont, 0, sizeof(PersonInfo) * MAX_CONTACT_SIZE);
	pcnt->capacity = MAX_CONTACT_SIZE;
	pcnt->size = 0;
}
bool IsFull(Contact* pcnt)
{
	return pcnt->size >= pcnt->capacity;
}

void AddContact(Contact* pcnt)
{
	//检查容量
	if (IsFull(pcnt))
	{
		printf("通讯录已满!");
		return;
	}
	printf("姓名:");
	scanf("%s", pcnt->Cont[pcnt->size].name);
	printf("性别:");
	scanf("%s", pcnt->Cont[pcnt->size].sex);
	printf("年龄:");
	scanf("%d", &pcnt->Cont[pcnt->size].age);
	printf("电话:");
	scanf("%s", pcnt->Cont[pcnt->size].tel);
	printf("地址:");
	scanf("%s", pcnt->Cont[pcnt->size].add);
	pcnt->size++;
	printf("增加人员信息成功!\n");
}
int FindByName(Contact* pcnt,char name[])
{
	for (int i = 0; i < pcnt->size; ++i)
	{
		if (strcmp(name, pcnt->Cont[i].name) == 0)
		{
			return i;
		}
	}
	return -1;
}

void FindContact(Contact* pcnt)
{
	if (IsEmpty(pcnt))
	{
		printf("通讯录为空!\n");
		return;
	}
	char name[MAX_NAME_SIZE];
	printf("请输入姓名:");
	scanf("%s", name);

	int index = FindByName(pcnt,name);
	if (index == -1)
	{
		printf("此人不存在!\n");
		return;
	}
	printf("%-15s%-15s%-15s%-15s%-15s", "姓名", "性别", "年龄", "电话", "地址");
	printf("\n");
	printf("%-13s%-13s%-13d%-13s%-13s\n", pcnt->Cont[index].name, pcnt->Cont[index].sex, pcnt->Cont[index].age, pcnt->Cont[index].tel, pcnt->Cont[index].add);
}
bool IsEmpty(Contact* pcnt)
{
	return pcnt->size == 0;
}
void ShowContact(Contact* pcnt)
{
	printf("%-15s%-15s%-15s%-15s%-15s","姓名","性别","年龄","电话","地址");
	printf("\n");
	for (int i = 0; i < pcnt->size; ++i)
	{
		printf("%-13s%-13s%-13d%-13s%-13s\n", pcnt->Cont[i].name, pcnt->Cont[i].sex, pcnt->Cont[i].age, pcnt->Cont[i].tel, pcnt->Cont[i].add);
	}
}
void ModifyContact(Contact* pcnt)
{
	if (IsEmpty(pcnt))
	{
		printf("通讯录为空!\n");
		return;
	}
	printf("请输入姓名:");
	char name[MAX_NAME_SIZE];
	scanf("%s", name);
	int index = FindByName(pcnt,name);
	if (index == -1)
	{
		printf("此人不存在!\n");
		return;
	}
	printf("你要修改什么信息(1-姓名 2-性别 3-年龄 4-电话 5-住址)\n");
	int sel;
	scanf("%d", &sel);
	switch (sel)
	{
	case 1:
		printf("请输入要修改的姓名:");
		scanf("%s", pcnt->Cont[index].name);
		break;
	case 2:
		printf("请输入要修改的性别:");
		scanf("%s", pcnt->Cont[index].sex);
		break;
	case 3:
		printf("请输入要修改的年龄:");
		scanf("%d",&pcnt->Cont[index].age);
		break;
	case 4:
		printf("请输入要修改的电话:");
		scanf("%s", pcnt->Cont[index].tel);
		break;
	case 5:
		printf("请输入要修改的地址:");
		scanf("%s", pcnt->Cont[index].add);
		break;
	}
}
void DelContact(Contact* pcnt)
{
	printf("请输入要删除的名字:");
	char name[MAX_NAME_SIZE];
	scanf("%s", name);
	int index = FindByName(pcnt, name);
	if (index == -1)
	{
		printf("此人不存在!\n");
		return;
	}
	for (int i = index; i < pcnt->size - 1; ++i)
	{
		pcnt->Cont[i] = pcnt->Cont[i + 1];
	}
	pcnt->size--;
	printf("删除完成!\n");
}
void ClearContact(Contact* pcnt)
{
	printf("是否确定 <Y/N> ?:\n");
	getchar();
	char ch = getchar();
	if (ch == 'Y' || ch == 'y')
	{
		pcnt->size = 0;
		printf("清除成功!\n");
		return;
	}
	else if(ch == 'N' || ch == 'n')
	{
		printf("清楚取消!\n");
		return;
	}
	printf("输入错误!\n");
}
void SortContact(Contact* pcnt)
{
	for (int i = 0; i < pcnt->size - 1; ++i)
	{
		for (int j = 0; j < pcnt->size - i - 1; ++j)
		{
			if (strcmp(pcnt->Cont[j].name, pcnt->Cont[j + 1].name) > 0)
			{
				PersonInfo tmp = pcnt->Cont[j];
				pcnt->Cont[j] = pcnt->Cont[j + 1];
				pcnt->Cont[j + 1] = tmp;
			}
		}
	}
	printf("排序成功!\n");
}

ContactMain.c

#include"contact.h"

int main(int argc, char* argv[])
{
	//初始化通讯录
	Contact cont;
	InitContact(&cont);
	
	int select = 1;
	while (select)
	{
		printf("***********************\n");
		printf("*  [1]Add   [2]Del    *\n");
		printf("*  [3]Find  [4]Modify *\n");
		printf("*  [5]Clear [6]Sort   *\n");
		printf("*  [7]Show  [0]Quit   *\n");
		printf("***********************\n");
		printf("请选择:");
		scanf("%d", &select);

		if (select == QUIT)
		{
			break;
		}

		switch (select)
		{
		case ADD:
			AddContact(&cont);
			break;
		case DEL:
			DelContact(&cont);
			break;
		case FIND:
			FindContact(&cont);
			break;
		case MODIFY:
			ModifyContact(&cont);
			break;
		case CLEAR:
			ClearContact(&cont);
			break;
		case SORT:
			SortContact(&cont);
			break;
		case SHOW:
			ShowContact(&cont);
			break;
		}
	}

	printf("再见");
	return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-27 09:43:57  更:2021-11-27 09:44:29 
 
开发: 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/6 14:04:14-

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