当前位置: 首页 > news >正文

通讯录(C++实现)

系统需求

通讯录是一个可以记录亲人、好友信息的工具。

本章主要利用C++来实现一个通讯录管理系统

系统中需要实现的功能如下:

添加联系人:向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录1000人

显示联系人:显示通讯录中所有联系人信息

删除联系人:按照姓名进行删除指定联系人

查找联系人:按照姓名查看指定联系人信息

修改联系人:按照姓名重新修改指定联系人

清空联系人:清空通讯录中所有信息

退出通讯录:退出当前使用的通讯录

菜单功能

功能描述:用户选择功能的界面

菜单界面效果如下图:

写成代码不难,就是利用“cout”打印

步骤:

  1. 封装函数显示该界面如void showMenu()

  1. 在main函数中调用封装好的函数

//菜单
void showMenu()
{cout << "*************************" << endl;cout << "***** 1、添加联系人 *****" << endl;cout << "***** 2、显示联系人 *****" << endl;cout << "***** 3、删除联系人 *****" << endl;cout << "***** 4、查找联系人 *****" << endl;cout << "***** 5、修改联系人 *****" << endl;cout << "***** 6、清空联系人 *****" << endl;cout << "***** 0、退出通讯录 *****" << endl;cout << "*************************" << endl;
}

然后我们在把“showMenu”写到主函数“main”里调用就行了。

退出功能

我们先来实现退出功能(因为它最简单)。但是在此之前我们要给用户做选择,而说到选择自然而然地离不开“switch”函数。

我们实现通讯录,不希望只是实现一次就完了,那么不可避免的要用“while”。

写成代码就是这样:

int main()
{//创建结构体变量Addressbooks abs;//初始化结构体1abs.m_Size = 0;while (true){//菜单调用showMenu();//输入变量int select = 0;//用户选择cout << "用户请选择:" << endl;cin >> select;switch (select){case 1://添加联系人{AddPerson(&abs);break;}case 2://显示联系人{showPerson(&abs);break;}case 3://删除联系人{deletePerson(&abs);break;}break;case 4://查找联系人{findPerson(&abs);break;}case 5://修改联系人{modifyPerson(&abs);break;}case 6://清空联系人cleanPerson(&abs);break;case 0://退出通讯录{break;}default:break;}}system("pause");return 0;
}

我们接下来看一下退出功能的具体实现。

功能描述:退出通讯录系统

思路:根据用户不同的选择,进入不同的功能,可以选择switch分支结构,将整个架构进行搭建

当用户选择0时候,执行退出,选择其他先不做操作,也不会退出程序

写成代码:

case 0://退出通讯录{cout << "欢迎下次使用" << endl;system("pause");return 0;break;}

设计联系人结构体

联系人信息包括:姓名、性别、年龄、联系电话、家庭住址

设计时候可以在通讯录结构体中,维护一个容量为1000的存放联系人的数组,并记录当前通讯录中联系人数量

//联系人结构体
struct Person
{string m_Name;int m_Sex;int m_Age;string m_Phone;string m_Addr;
};
//通讯录结构体
#define MAX 1000//最大人数struct Addressbooks
{Person PersonArray[MAX];int m_Size;//当前结构体人数的个数
};

添加联系人

功能描述:

实现添加联系人功能,联系人上限为1000人,联系人信息包括(姓名、性别、年龄、联系电话、家庭住址)

添加联系人实现步骤:

  • 设计联系人结构体

  • 设计通讯录结构体

  • main函数中创建通讯录

  • 封装添加联系人函数

  • 测试添加联系人功能

将思路转换为代码就是:

//添加联系人
void AddPerson(Addressbooks* abs)
{//判断是否满了if (abs->m_Size == MAX){cout << "通讯录已满" << endl;return;}string name;cout << "请输入姓名:" << endl;cin >> name;abs->PersonArray[abs->m_Size].m_Name = name;int sex = 0;cout << "请输入性别:" << endl;cout << "1、男  2、女" << endl;while (true){cin >> sex;if (sex == 1 || sex == 2){abs->PersonArray[abs->m_Size].m_Sex = sex;break;}else{cout << "输入错误,请重新输入" << endl;continue;}}cout << "请输入年龄:" << endl;int age = 0;cin >> age;abs->PersonArray[abs->m_Size].m_Age = age;cout << "请输入电话号码:" << endl;string phone = "0";cin >> phone;abs->PersonArray[abs->m_Size].m_Phone = phone;cout << "请输入家庭地址:" << endl;string addr = "0";cin >> addr;abs->PersonArray[abs->m_Size].m_Addr = addr;//更新通讯录中的人数abs->m_Size++;cout << "添加成功" << endl;system("pause");system("cls");
}

system("pause"):按任意键继续

system("cls"):清屏操作

注意:cls 是windows下的,Linux下是clear

显示联系人

功能描述:显示通讯录中已有的联系人信息

显示联系人实现步骤:

  • 封装显示联系人函数

  • 测试显示联系人功能

封装显示联系人函数

思路:判断如果当前通讯录中没有人员,就提示记录为空,人数大于0,显示通讯录中信息

//显示联系人
void showPerson(Addressbooks* abs)
{//判断if (abs->m_Size == 0){cout << "当前通讯录未添加人\n";}else{for (int i = 0; i < abs->m_Size; i++){cout << "姓名:" << abs->PersonArray[i].m_Name << "\t";;cout << "性别:" << (abs->PersonArray[i].m_Sex == 1 ? "男" : "女") << "\t";cout << "年龄:" << abs->PersonArray[i].m_Age << "\t";cout << "电话:" << abs->PersonArray[i].m_Phone << "\t";cout << "地址:" << abs->PersonArray[i].m_Addr << endl;}}system("pause");system("cls");
}

删除联系人

功能描述:按照姓名进行删除指定联系人

删除联系人实现步骤:

  • 封装检测联系人是否存在

  • 封装删除联系人函数

  • 测试删除联系人功能

封装检测联系人是否存在

设计思路:

删除联系人前,我们需要先判断用户输入的联系人是否存在,如果存在删除,不存在提示用户没有要删除的联系人因此我们可以把检测联系人是否存在封装成一个函数中,如果存在,返回联系人在通讯录中的位置,不存在返回-1

封装删除联系人函数

根据用户输入的联系人判断该通讯录中是否有此人

查找到进行删除,并提示删除成功

查不到提示查无此人。

我们先来做一个查找函数

int isExist(Addressbooks* abs, string name)
{//遍历所有人for (int i = 0; i < abs->m_Size; i++){if (abs->PersonArray[i].m_Name == name){return i;}}//没有找到的情况return -1;system("pause");system("cls");
}

试验一下,判断能否查找到人

//实验一下cout << "请输入要查找的人:" << endl;string name = "0";cin >> name;if (isExist(&abs, name) == -1){cout << "查无此人" << endl;}else{cout << "找到此人" << endl;}}

删除函数的实现:

void deletePerson(Addressbooks* abs)
{ cout << "请输入要删除的人:" << endl;string name;cin >> name;//是否存在int ret = isExist(abs, name);if (ret == -1){cout << "查无此人" << endl;return;}else{for (int i = ret; i < abs->m_Size; i++){abs->PersonArray[i] = abs->PersonArray[i + 1];}abs->m_Size--;cout << "删除成功\n";system("pause");system("cls");}
}

查找联系人

功能描述:按照姓名查看指定联系人信息

查找联系人实现步骤

  • 封装查找联系人函数

  • 测试查找指定联系人

封装查找联系人函数

实现思路:判断用户指定的联系人是否存在,如果存在显示信息,不存在则提示查无此人。

void findPerson(Addressbooks* abs)
{cout << "请输入要查找的人:" << endl;string name;cin >> name;int i = isExist(abs, name);if (i == -1){cout << "查无此人" << endl;}else{cout << "姓名:" << abs->PersonArray[i].m_Name << "\t";;cout << "性别:" << (abs->PersonArray[i].m_Sex == 1 ? "男" : "女") << "\t";cout << "年龄:" << abs->PersonArray[i].m_Age << "\t";cout << "电话:" << abs->PersonArray[i].m_Phone << "\t";cout << "地址:" << abs->PersonArray[i].m_Addr << endl;}system("pause");system("cls");
}

修改联系人

功能描述:按照姓名重新修改指定联系人

修改联系人实现步骤:

  • 封装修改联系人函数

  • 测试修改联系人功能

封装修改联系人函数

实现思路:查找用户输入的联系人,如果查找成功进行修改操作查找失败提示查无此人

void modifyPerson(Addressbooks* abs)
{cout << "请输入要修改的人:" << endl;string name;cin >> name;int i = isExist(abs, name);if (i == -1){cout << "查无此人" << endl;}else{cout << "请输入姓名:" << endl;cin >> name;abs->PersonArray[i].m_Name = name;int sex = 0;cout << "请输入性别:" << endl;cout << "1、男  2、女" << endl;while (true){cin >> sex;if (sex == 1 || sex == 2){abs->PersonArray[i].m_Sex = sex;break;}else{cout << "输入错误,请重新输入" << endl;continue;}}cout << "请输入年龄:" << endl;int age = 0;cin >> age;abs->PersonArray[i].m_Age = age;cout << "请输入电话号码:" << endl;string phone = "0";cin >> phone;abs->PersonArray[i].m_Phone = phone;cout << "请输入家庭地址:" << endl;string addr = "0";cin >> addr;abs->PersonArray[i].m_Addr = addr;system("pause");system("cls");}
}

清空联系人

功能描述:清空通讯录中所有信息

清空联系人实现步骤

封装清空联系人函数

测试清空联系人

封装清空联系人函数

实现思路:将通讯录所有联系人信息清除掉,只要将通讯录记录的联系人数量置为0,做逻辑清空即可。清空联系人代码:

void cleanPerson(Addressbooks* abs)
{abs->m_Size = 0;cout << "清除成功" << endl;system("pause");system("cls");
}

整体代码

为了避免大家更好的测试代码,我将整个代码复制下来,以便于小伙伴们对照学习。

#include<iostream>
#include<string>
using namespace std;//菜单
void showMenu()
{cout << "*************************" << endl;cout << "***** 1、添加联系人 *****" << endl;cout << "***** 2、显示联系人 *****" << endl;cout << "***** 3、删除联系人 *****" << endl;cout << "***** 4、查找联系人 *****" << endl;cout << "***** 5、修改联系人 *****" << endl;cout << "***** 6、清空联系人 *****" << endl;cout << "***** 0、退出通讯录 *****" << endl;cout << "*************************" << endl;
}
//联系人结构体
struct Person
{string m_Name;int m_Sex;int m_Age;string m_Phone;string m_Addr;
};
//通讯录结构体
#define MAX 1000//最大人数struct Addressbooks
{Person PersonArray[MAX];int m_Size;//当前结构体人数的个数
};//添加联系人
void AddPerson(Addressbooks* abs)
{//判断是否满了if (abs->m_Size == MAX){cout << "通讯录已满" << endl;return;}string name;cout << "请输入姓名:" << endl;cin >> name;abs->PersonArray[abs->m_Size].m_Name = name;int sex = 0;cout << "请输入性别:" << endl;cout << "1、男  2、女" << endl;while (true){cin >> sex;if (sex == 1 || sex == 2){abs->PersonArray[abs->m_Size].m_Sex = sex;break;}else{cout << "输入错误,请重新输入" << endl;continue;}}cout << "请输入年龄:" << endl;int age = 0;cin >> age;abs->PersonArray[abs->m_Size].m_Age = age;cout << "请输入电话号码:" << endl;string phone = "0";cin >> phone;abs->PersonArray[abs->m_Size].m_Phone = phone;cout << "请输入家庭地址:" << endl;string addr = "0";cin >> addr;abs->PersonArray[abs->m_Size].m_Addr = addr;//更新通讯录中的人数abs->m_Size++;cout << "添加成功" << endl;system("pause");system("cls");
}
//显示联系人
void showPerson(Addressbooks* abs)
{//判断if (abs->m_Size == 0){cout << "当前通讯录未添加人\n";}else{for (int i = 0; i < abs->m_Size; i++){cout << "姓名:" << abs->PersonArray[i].m_Name << "\t";;cout << "性别:" << (abs->PersonArray[i].m_Sex == 1 ? "男" : "女") << "\t";cout << "年龄:" << abs->PersonArray[i].m_Age << "\t";cout << "电话:" << abs->PersonArray[i].m_Phone << "\t";cout << "地址:" << abs->PersonArray[i].m_Addr << endl;}}system("pause");system("cls");
}int isExist(Addressbooks* abs, string name)
{//遍历所有人for (int i = 0; i < abs->m_Size; i++){if (abs->PersonArray[i].m_Name == name){return i;}}//没有找到的情况return -1;system("pause");system("cls");
}void findPerson(Addressbooks* abs)
{cout << "请输入要查找的人:" << endl;string name;cin >> name;int i = isExist(abs, name);if (i == -1){cout << "查无此人" << endl;}else{cout << "姓名:" << abs->PersonArray[i].m_Name << "\t";;cout << "性别:" << (abs->PersonArray[i].m_Sex == 1 ? "男" : "女") << "\t";cout << "年龄:" << abs->PersonArray[i].m_Age << "\t";cout << "电话:" << abs->PersonArray[i].m_Phone << "\t";cout << "地址:" << abs->PersonArray[i].m_Addr << endl;}system("pause");system("cls");
}void modifyPerson(Addressbooks* abs)
{cout << "请输入要修改的人:" << endl;string name;cin >> name;int i = isExist(abs, name);if (i == -1){cout << "查无此人" << endl;}else{cout << "请输入姓名:" << endl;cin >> name;abs->PersonArray[i].m_Name = name;int sex = 0;cout << "请输入性别:" << endl;cout << "1、男  2、女" << endl;while (true){cin >> sex;if (sex == 1 || sex == 2){abs->PersonArray[i].m_Sex = sex;break;}else{cout << "输入错误,请重新输入" << endl;continue;}}cout << "请输入年龄:" << endl;int age = 0;cin >> age;abs->PersonArray[i].m_Age = age;cout << "请输入电话号码:" << endl;string phone = "0";cin >> phone;abs->PersonArray[i].m_Phone = phone;cout << "请输入家庭地址:" << endl;string addr = "0";cin >> addr;abs->PersonArray[i].m_Addr = addr;system("pause");system("cls");}}void deletePerson(Addressbooks* abs)
{ cout << "请输入要删除的人:" << endl;string name;cin >> name;//是否存在int ret = isExist(abs, name);if (ret == -1){cout << "查无此人" << endl;return;}else{for (int i = ret; i < abs->m_Size; i++){abs->PersonArray[i] = abs->PersonArray[i + 1];}abs->m_Size--;cout << "删除成功\n";system("pause");system("cls");}
}void cleanPerson(Addressbooks* abs)
{abs->m_Size = 0;cout << "清除成功" << endl;system("pause");system("cls");
}int main()
{//创建结构体变量Addressbooks abs;//初始化结构体1abs.m_Size = 0;while (true){//菜单调用showMenu();//输入变量int select = 0;//用户选择cout << "用户请选择:" << endl;cin >> select;switch (select){case 1://添加联系人{AddPerson(&abs);break;}case 2://显示联系人{showPerson(&abs);break;}case 3://删除联系人{deletePerson(&abs);break;}break;case 4://查找联系人{findPerson(&abs);break;}case 5://修改联系人{modifyPerson(&abs);break;}case 6://清空联系人cleanPerson(&abs);break;case 0://退出通讯录{cout << "欢迎下次使用" << endl;system("pause");return 0;break;}default:break;}}system("pause");return 0;
}

总结

我们利用了C++基础知识完成了通讯录,大家在对照学习过程中可以很好的发现自己在哪方面的语法有什么不足点。如果大家能够理解通讯录了,说明大家在初学C++上迈出了重要的一步。希望大家能够有所收获,而不是仅仅只是复制了代码。

最后恭喜大家!正式迈入C++世界的大门。

欢迎大家点赞收藏!

相关文章:

通讯录(C++实现)

系统需求通讯录是一个可以记录亲人、好友信息的工具。本章主要利用C来实现一个通讯录管理系统系统中需要实现的功能如下:添加联系人:向通讯录中添加新人&#xff0c;信息包括&#xff08;姓名、性别、年龄、联系电话、家庭住址&#xff09;最多记录1000人显示联系人:显示通讯录…...

轻松掌握C++的模板与类模板,将Tamplate广泛运用于我们的编程生活

C提高编程 本阶段主要针对C泛型编程和STL技术做详细讲解&#xff0c;探讨C更深层的使用 泛型编程:编写与类型无关的通用代码,是代码复用的一种手段。 模板 1.模板的概念 模板就是建立通用的模具&#xff0c;大大提高复用性 例如&#xff1a; 2.函数模板 C另一种编程思想称…...

pandas 数据预处理+数据概览 处理技巧整理(持续更新版)

这篇文章主要是整理下使用pandas的一些技巧&#xff0c;因为经常不用它&#xff0c;这些指令忘得真的很快。前段时间在数模美赛中已经栽过跟头了&#xff0c;不希望以后遇到相关问题的时候还去网上查&#xff08;主要是太杂了&#xff09;。可能读者跟我有一样的问题&#xff0…...

mmdetectionV2.x版本 训练自己的VOC数据集

mmdetection目录下创建data文件夹&#xff0c;路劲如图所示&#xff0c;不带yololabels 修改配置文件 mmdet/datasets/voc.py 配置图片格式 mmdet/datasets/xml_style.py 如果图片是jpg则改成jpg&#xff0c;是png格式就改成png&#xff0c;这里我不需要改&#xff0c;本…...

Shell - crontab 定时 git 拉取并执行 maven 打包

目录 一.引言 二.踩坑与实践 1.原始代码 2.mvn package 未执行与解决 [导入环境变量] 3.git pull 未执行与解决 [添加绝对路径] 三.总结 一.引言 git 任务部署在通道机&#xff0c;每天6点需要定时更新 jar 包并打包上线&#xff0c;所以需要在 linux 服务器上&#xff…...

408考研计算机之计算机组成与设计——知识点及其做题经验篇目3:指令的寻址方式

上篇文章我们讲到&#xff0c;指令的基本格式&#xff0c;一条指令通常包括操作码字段和地址码字段两部分&#xff1a; 操作码字段地址码字段并且我们还讲到根据操作数地址码的数目不同&#xff0c;可将指令分为零一二三四地址指令。感兴趣的小伙伴们可以看看小编的上一篇文章…...

前端包管理工具:npm,yarn、cnpm、npx、pnpm

包管理工具npm Node Package Manager&#xff0c;也就是Node包管理器&#xff1b; 但是目前已经不仅仅是Node包管理器了&#xff0c;在前端项目中我们也在使用它来管理依赖的包&#xff1b; 比如vue、vue-router、vuex、express、koa、react、react-dom、axios、babel、webpack…...

推荐系统 FM因式分解

reference&#xff1a;知乎 FM算法解析 LR算法没有二阶交叉 如果是id类特征&#xff0c;这里的x是0/1&#xff0c;raw的特征输入就是float&#xff0c;当然&#xff0c;在我的理解里&#xff0c;一般会把raw的特征进行分桶&#xff0c;还是映射到0/1特征&#xff0c;不然这个w…...

Maven基础入门

文章目录Maven简介Maven 工作模式1.仓库2.坐标Maven的基本使用1.常用命令2.生命周期依赖管理1.依赖配置2.依赖传递3.可选依赖4.排除依赖5.依赖范围IDEA配置MavenMaven简介 Apache Maven 是一个项目管理和构建工具&#xff0c;它基于项目对象模型(POM)的概念&#xff0c;通过一…...

传输层协议 TCP UDP

目录 协议前菜 端口号 ​编辑端口号范围划分 认识知名端口号(Well-Know Port Number) netstat pidof 传输层协议 UDP协议 UDP协议端格式 UDP的特点 面向数据报 UDP的缓冲区 UDP使用注意事项 基于UDP的应用层协议 TCP协议 TCP协议概念 TCP协议段格式 标志…...

一点就分享系列(实践篇6——上篇)【迟到补发】Yolo-High_level系列算法开源项目融入V8 旨在研究和兼容使用【持续更新】

一点就分享系列&#xff08;实践篇5-补更篇&#xff09;[迟到补发]—Yolo系列算法开源项目融入V8旨在研究和兼容使用[持续更新] 题外话 去年我一直复读机式强调High-level在工业界已经饱和的情况&#xff0c;目的是呼吁更多人看准自己&#xff0c;不管是数字孪生交叉领域&#…...

buu RSA 1 (Crypto 第一页)

题目描述&#xff1a; 两个文件&#xff0c;都用记事本打开&#xff0c;记住用记事本打开 pub.key: -----BEGIN PUBLIC KEY----- MDwwDQYJKoZIhvcNAQEBBQADKwAwKAIhAMAzLFxkrkcYL2wch21CM2kQVFpY97 /AvKr1rzQczdAgMBAAE -----END PUBLIC KEY-----flag.enc: A柪YJ^ 柛x秥?y…...

Python 二分查找:bisect库的使用

✅作者简介&#xff1a;人工智能专业本科在读&#xff0c;喜欢计算机与编程&#xff0c;写博客记录自己的学习历程。 &#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&…...

性能优化之HBase性能调优

HBase是Hadoop生态系统中的一个组件&#xff0c;是一个分布式、面向列存储的内存型开源数据库&#xff0c;可以支持数百万列&#xff08;MySQL4张表在HBase中对应1个表&#xff0c;4个列&#xff09;、超过10亿行的数据存储。可用作&#xff1a;冷热数据分离HBase适合作为冷数据…...

图像金字塔,原理、实现及应用

什么是图像金字塔 图像金字塔是对图像的一种多尺度表达&#xff0c;将各个尺度的图像按照分辨率从小到大&#xff0c;依次从上到下排列&#xff0c;就会形成类似金字塔的结构&#xff0c;因此称为图像金字塔。 常见的图像金字塔有两类&#xff0c;一种是高斯金字塔&#xff0…...

08-Oracle游标管理(定义,打开、获取数据及关闭游标)

目标 1.确定何时需要显示游标2.声明、打开和关闭显示游标3.从显示游标中提取数据4.了解与游标有关的属性5.使用游标FOR循环检索游标中的数据6.在游标FOR循环的子查询中声明游标7.评估使用逻辑运算符结合在一起的布尔条件游标 1、在使用一个PL/SQL块来执行DML语句或只返回一行结…...

Python判断字符串是否包含特定子串的7种方法

目录1、使用 in 和 not in2、使用 find 方法3、使用 index 方法4、使用 count 方法5、通过魔法方法6、借助 operator7、使用正则匹配转自&#xff1a;https://cloud.tencent.com/developer/article/1699719我们经常会遇这样一个需求&#xff1a;判断字符串中是否包含某个关键词…...

aop实现接口访问频率限制

引言 项目开发中我们有时会用到一些第三方付费的接口&#xff0c;这些接口的每次调用都会产生一些费用&#xff0c;有时会有别有用心之人恶意调用我们的接口&#xff0c;造成经济损失&#xff1b;或者有时需要对一些执行时间比较长的的接口进行频率限制&#xff0c;这里我就简…...

Hive---窗口函数

Hive窗口函数 其他函数: Hive—Hive函数 文章目录Hive窗口函数开窗数据准备建表导入数据聚合函数window子句LAG(col,n,default_val) 往前第 n 行数据LEAD(col,n, default_val) 往后第 n 行数据ROW_NUMBER() 会根据顺序计算RANK() 排序相同时会重复&#xff0c;总数不会变DENSE…...

JavaSe第7次笔记

1. C语言里面&#xff0c;NULL是0地址。Java中null和0地址没关系。 2.数组可以做方法的返回值。 3.可以使用变量作为数组的个数开辟空间。 4.断言assert&#xff0c;需要设置。 5.排序&#xff1a;Arrays. sort(array); 6.查找&#xff1a; int index Arrays. binarySea…...

工业安全零事故的智能守护者:一体化AI智能安防平台

前言&#xff1a; 通过AI视觉技术&#xff0c;为船厂提供全面的安全监控解决方案&#xff0c;涵盖交通违规检测、起重机轨道安全、非法入侵检测、盗窃防范、安全规范执行监控等多个方面&#xff0c;能够实现对应负责人反馈机制&#xff0c;并最终实现数据的统计报表。提升船厂…...

MFC内存泄露

1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件

今天呢&#xff0c;博主的学习进度也是步入了Java Mybatis 框架&#xff0c;目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学&#xff0c;希望能对大家有所帮助&#xff0c;也特别欢迎大家指点不足之处&#xff0c;小生很乐意接受正确的建议&…...

cf2117E

原题链接&#xff1a;https://codeforces.com/contest/2117/problem/E 题目背景&#xff1a; 给定两个数组a,b&#xff0c;可以执行多次以下操作&#xff1a;选择 i (1 < i < n - 1)&#xff0c;并设置 或&#xff0c;也可以在执行上述操作前执行一次删除任意 和 。求…...

Python如何给视频添加音频和字幕

在Python中&#xff0c;给视频添加音频和字幕可以使用电影文件处理库MoviePy和字幕处理库Subtitles。下面将详细介绍如何使用这些库来实现视频的音频和字幕添加&#xff0c;包括必要的代码示例和详细解释。 环境准备 在开始之前&#xff0c;需要安装以下Python库&#xff1a;…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)

本期内容并不是很难&#xff0c;相信大家会学的很愉快&#xff0c;当然对于有后端基础的朋友来说&#xff0c;本期内容更加容易了解&#xff0c;当然没有基础的也别担心&#xff0c;本期内容会详细解释有关内容 本期用到的软件&#xff1a;yakit&#xff08;因为经过之前好多期…...

【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习

禁止商业或二改转载&#xff0c;仅供自学使用&#xff0c;侵权必究&#xff0c;如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...

Yolov8 目标检测蒸馏学习记录

yolov8系列模型蒸馏基本流程&#xff0c;代码下载&#xff1a;这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中&#xff0c;**知识蒸馏&#xff08;Knowledge Distillation&#xff09;**被广泛应用&#xff0c;作为提升模型…...

jmeter聚合报告中参数详解

sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample&#xff08;样本数&#xff09; 表示测试中发送的请求数量&#xff0c;即测试执行了多少次请求。 单位&#xff0c;以个或者次数表示。 示例&#xff1a;…...