【数据结构】03.顺序表的应用——通讯录

本篇文章我们将使用顺序表来实现通讯录的增删查改功能。
代码如下:

//Contact.h
 
#pragma once
 
#define NAME_MAX 30
#define GENDER_MAX 10
#define ADDRESS_MAX 100
#define TEL_MAX 12
 
enum{Exit,Add,Del,Seek,Change,Show};//枚举类型,便于理解数字含义
 
//通讯录结构体
typedef struct PeopleInfo
{
	char name[NAME_MAX];
	int age;
	char gender[GENDER_MAX];
	char address[ADDRESS_MAX];
	char tel[TEL_MAX];
}Info;
 
struct SL;
typedef struct SL Contact;
 
void ContactInit(Contact* con);//通讯录初始化
void ContactDestroy(Contact* con);//通讯录销毁
void ContactAdd(Contact* con);//添加联系人
void ContactDel(Contact* con);//删除联系人
void ContactSeek(Contact* con);//查找联系人
void ContactChange(Contact* con);//修改联系人
void ContactShow(Contact* con);//展示通讯录
//Contact.c
#include "order_table.h"
 
void ContactInit(Contact* con)//通讯录初始化
{
	init(con);
}
void ContactDestroy(Contact* con)//通讯录销毁
{
	SLDestory(con);
}
 
void ContactAdd(Contact* con)//通讯录添加
{
	Info s;
	printf("请输入姓名:\n");
	scanf("%s", s.name);
	printf("请输入年龄:\n");
	scanf("%d", &s.age);
	printf("请输入性别:\n");
	scanf("%s", s.gender);
	printf("请输入地址:\n");
	scanf("%s", s.address);
	printf("请输入电话号码:\n");
	scanf("%s", s.tel);
 
	Insert(con, 0, s);//调用顺序表
	printf("添加成功!\n");
}
 
int FindInName(Contact* con,char* name)//自定义的按名字查找函数
{
	for (int i = 0; i < con->size; i++)
	{
		if (strcmp(name, con->a[i].name) == 0)
		{
			return i;
		}
	}
	return -1;
}
 
void ContactDel(Contact* con)//删除联系人
{
	char name[30];
	printf("请输入你要删除的人的姓名:\n");
	scanf("%s", name);
 
	int pos = FindInName(con,name);
	if (pos == -1)
	{
		printf("未找到该联系人,删除失败\n");
		return;
	}
	Erase(con, pos);//调用顺序表
	printf("删除成功!\n");
}
 
void ContactSeek(Contact* con)
{
	char name[30] = { 0 };
	printf("请输入你要查找的人的姓名:\n");
	scanf("%s", name);
 
	int ret = FindInName(con,name);
	if (ret == -1)
	{
		printf("没找到该联系人!\n");
		return;
	}
	printf("找到了,该联系人编号为%d\n", ret);
}
 
 
void ContactChange(Contact* con)
{
	char name[30] = { 0 };
	printf("请输入你要修改的人的姓名:\n");
	scanf("%s", name);
 
	int pos = FindInName(con,name);
	if (pos == -1)
	{
		printf("未找到该联系人,修改失败!\n");
		return;
	}
	printf("请输入姓名:\n");
	scanf("%s", con->a[pos].name);
	printf("请输入年龄:\n");
	scanf("%d", &con->a[pos].age);
	printf("请输入性别:\n");
	scanf("%s", con->a[pos].gender);
	printf("请输入地址:\n");
	scanf("%s", con->a[pos].address);
	printf("请输入电话号码:\n");
	scanf("%s", con->a[pos].tel);
	printf("修改成功!\n");
}
void ContactShow(Contact* con)
{
	printf("姓名\t年龄\t性别\t地址\t电话号码\n");
	for (int i = 0; i < con->size; i++)
	{
		printf("%s\t%d\t%s\t%s\t%s\n", 
			            con->a[i].name,
			            con->a[i].age, 
			            con->a[i].gender,
			            con->a[i].address,
			            con->a[i].tel);
	}
}
//test.c
#include"order_table.h"
 
void menu(void)
{
	printf("*****************通讯录****************\n");
	printf("*****1.添加联系人     2.删除联系人*****\n");
	printf("*****3.查找联系人     4.修改联系人*****\n");
	printf("*****5.展示通讯录     0.退出通讯录*****\n");
	printf("***************************************\n");
}
 
 
int main()
{
	Contact con;
	ContactInit(&con);
 
	int input = 0;
	do
	{
		menu();
		printf("请输入你要进行的操作:");
		scanf("%d", &input);
		
		switch (input)
		{
		case Exit:
			printf("退出通讯录中……\n");
			break;
		case Add:
			ContactAdd(&con);
			break;
		case Del:
			ContactDel(&con);
			break;
		case Seek:
			ContactSeek(&con);
			break;
		case Change:
			ContactChange(&con);
			break;
		case Show:
			ContactShow(&con);
			break;
		default:
			printf("输入错误,请重新输入!\n");
			break;
		}
	} while (input);
	ContactDestroy(&con);
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/778483.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【JVM 的内存模型】

1. JVM内存模型 下图为JVM内存结构模型&#xff1a; 两种执行方式&#xff1a; 解释执行&#xff1a;JVM是由C语言编写的&#xff0c;其中有C解释器&#xff0c;负责先将Java语言解释翻译为C语言。缺点是经过一次JVM翻译&#xff0c;速度慢一点。JIT执行&#xff1a;JIT编译器…

7 动态规划

下面的例子不错&#xff1a; 对于动态规划&#xff0c;能学到不少东西&#xff1b; 你要清楚每一步都在做什么&#xff0c;划分细致就能够拆解清楚&#xff01; xk. - 力扣&#xff08;LeetCode&#xff09; labuladong的算法笔记-动态规划-CSDN博客 动态规划是一种强大的算法…

nginx的正向代理和反向代理以及tomcat

nginx的正向代理和反向代理&#xff1a; 正向代理以及缓存配置&#xff1a; 代理&#xff1a;客户端不再是直接访问服务端&#xff0c;通过代理服务器访问服务端。 正向代理&#xff1a;面向客户端&#xff0c;我们通过代理服务器的IP地址访问目标范围端。 服务端只知道代理…

绝区叁--如何在移动设备上本地运行LLM

随着大型语言模型 (LLM)&#xff08;例如Llama 2和Llama 3&#xff09;不断突破人工智能的界限&#xff0c;它们正在改变我们与周围技术的互动方式。这些模型早已集成到我们的手机中&#xff0c;但到目前为止&#xff0c;它们理解和处理请求的能力还非常有限。然而&#xff0c;…

【C++】模板进阶--保姆级解析(什么是非类型模板参数?什么是模板的特化?模板的特化如何应用?)

目录 一、前言 二、什么是C模板&#xff1f; &#x1f4a6;泛型编程的思想 &#x1f4a6;C模板的分类 三、非类型模板参数 ⚡问题引入⚡ ⚡非类型模板参数的使用⚡ &#x1f525;非类型模板参数的定义 &#x1f525;非类型模板参数的两种类型 &#x1f52…

使用 ESP32-WROOM + DHT11 做个无屏温湿度计

最近梅雨天&#xff0c;有个房间湿度很大&#xff0c;而我需要远程查看温湿度&#xff0c;所以无所谓有没有显示屏&#xff0c;某宝上的温湿度计都是带屏的&#xff0c;如果连WIFI查看温湿度操作也比较麻烦&#xff0c;还需要换电池&#xff0c;实在不能满足我的需求&#xff0…

剖析DeFi交易产品之UniswapV3:交易路由合约

本文首发于公众号&#xff1a;Keegan小钢 SwapRouter 合约封装了面向用户的交易接口&#xff0c;但不再像 UniswapV2Router 一样根据不同交易场景拆分为了那么多函数&#xff0c;UniswapV3 的 SwapRouter 核心就只有 4 个交易函数&#xff1a; exactInputSingle&#xff1a;指…

Vue进阶(四十五)Jest集成指南

文章目录 一、前言二、环境检测三、集成问题汇总四、拓展阅读 一、前言 在前期博文《Vue进阶&#xff08;八十八&#xff09;Jest》中&#xff0c;讲解了Jest基本用法及应用示例。一切顺利的话&#xff0c;按照文档集成应用即可&#xff0c;但是集成过程中遇到的问题可能五花八…

【WEB前端2024】3D智体编程:乔布斯3D纪念馆-第55课-芝麻开门(语音 识别 控制3D纪念馆开门 和 关门)

【WEB前端2024】3D智体编程&#xff1a;乔布斯3D纪念馆-第55课-芝麻开门&#xff08;语音识别控制3D纪念馆开门和关门&#xff09; 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtn…

KVM使用命令行添加新磁盘(注:支持热插拔)

1、使用qemu-img创建格式为qcow2的磁盘 [rootkvm ~]# qemu-img create -f qcow2 /var/lib/libvirt/images/test-disk.qcow2 15G 2、显示虚拟机硬盘列表&#xff0c;查看未使用的target [rootkvm ~]# virsh domblklist kvm-client 3、添加硬盘到kvm-client虚拟机中 [rootkvm…

SpringBoot | 大新闻项目后端(redis优化登录)

该项目的前篇内容的使用jwt令牌实现登录认证&#xff0c;使用Md5加密实现注册&#xff0c;在上一篇&#xff1a;http://t.csdnimg.cn/vn3rB 该篇主要内容&#xff1a;redis优化登录和ThreadLocal提供线程局部变量&#xff0c;以及该大新闻项目的主要代码。 redis优化登录 其实…

html+css+js图片手动轮播

源代码在界面图片后面 轮播演示用的几张图片是Bing上的&#xff0c;直接用的几张图片的URL&#xff0c;谁加载可能需要等一下&#xff0c;现实中替换成自己的图片即可 关注一下点个赞吧&#x1f604; 谢谢大佬 界面图片 源代码 <!DOCTYPE html> <html lang&quo…

C++继承初识

一。继承 1.继承本质是复用相同的代码&#xff08;属性&#xff09; 2.格式&#xff1a;class 类名&#xff1a;继承方式 父类 3.继承方式的规律&#xff1a; 父类的&#xff1a; 对于私有成员&#xff0c;不管哪种继承方式都不可见--->不想被子类继承的成员 对于保护…

代码随想录——划分字母区间(Leetcode763)

题目链接 贪心 class Solution {public List<Integer> partitionLabels(String s) {int[] count new int[27];Arrays.fill(count,0);// 统计元素最后一次出现的位置for(int i 0; i < s.length(); i){count[s.charAt(i) - a] i;}List<Integer> res new Ar…

非对称加密算法原理与应用2——RSA私钥加密文件

作者:私语茶馆 1.相关章节 (1)非对称加密算法原理与应用1——秘钥的生成-CSDN博客 第一章节讲述的是创建秘钥对,并将公钥和私钥导出为文件格式存储。 本章节继续讲如何利用私钥加密内容,包括从密钥库或文件中读取私钥,并用RSA算法加密文件和String。 2.私钥加密的概述…

JDK都出到20多了,你还不会使用JDK8的Stream流写代码吗?

目录 前言 Stream流 是什么&#xff1f; 为什么要用Steam流 常见stream流使用案例 映射 map() & 集合 collect() 单字段映射 多字段映射 映射为其他的对象 映射为 Map 去重 distinct() 过滤 filter() Stream流的其他方法 使用Stream流的弊端 前言 当你某天看…

深度学习模型加密python版本

支持加密的模型: # torch、torch script、onnx、tensorrt 、torch2trt、tensorflow、tensorflow2tensorrt、paddlepaddle、paddle2tensorrt 深度学习推理模型通常以文件的形式进行保存&#xff0c;相应的推理引擎通过读取模型文件并反序列化即可进行推理过程. 这样一来&#…

跨平台Ribbon UI组件QtitanRibbon全新发布v6.7.0——支持Qt 6.6.3

没有Microsoft在其办公解决方案中提供的界面&#xff0c;就无法想象现代应用程序&#xff0c;这个概念称为Ribbon UI&#xff0c;目前它是使应用程序与时俱进的主要属性。QtitanRibbon是一款遵循Microsoft Ribbon UI Paradigm for Qt技术的Ribbon UI组件&#xff0c;QtitanRibb…

vue3【实战】来回拖拽放置图片

效果预览 技术要点 img 标签默认就是可拖拽的&#xff08;a 标签也是&#xff09;事件 e 内的 dataTransfer 对象可用于临时存储事件过程中的数据拖拽事件的默认行为是用浏览器新开页签打开被拖拽对象&#xff0c;所以通常需要禁用默认的浏览器行为被拖拽元素必须设置 id&#…

拉曼光谱入门:2.拉曼光谱发展史、拉曼效应与试样温度的确定方法

1.拉曼光谱技术发展史 这里用简单的箭头与关键字来概括一下拉曼光谱技术的发展史 1928年&#xff1a;拉曼效应的发现 → 拉曼光谱术的初步应用20世纪40年代&#xff1a;红外光谱术的发展 → 拉曼光谱术的限制20世纪60年代&#xff1a;激光作为光源的引入 → 拉曼光谱术的性能提…