当前位置: 首页 > 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…...

STM32标准库-DMA直接存储器存取

文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA&#xff08;Direct Memory Access&#xff09;直接存储器存取 DMA可以提供外设…...

《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》

在注意力分散、内容高度同质化的时代&#xff0c;情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现&#xff0c;消费者对内容的“有感”程度&#xff0c;正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中&#xff0…...

Python实现prophet 理论及参数优化

文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候&#xff0c;写过一篇简单实现&#xff0c;后期随着对该模型的深入研究&#xff0c;本次记录涉及到prophet 的公式以及参数调优&#xff0c;从公式可以更直观…...

【项目实战】通过多模态+LangGraph实现PPT生成助手

PPT自动生成系统 基于LangGraph的PPT自动生成系统&#xff0c;可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析&#xff1a;自动解析Markdown文档结构PPT模板分析&#xff1a;分析PPT模板的布局和风格智能布局决策&#xff1a;匹配内容与合适的PPT布局自动…...

leetcodeSQL解题:3564. 季节性销售分析

leetcodeSQL解题&#xff1a;3564. 季节性销售分析 题目&#xff1a; 表&#xff1a;sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...

蓝桥杯3498 01串的熵

问题描述 对于一个长度为 23333333的 01 串, 如果其信息熵为 11625907.5798&#xff0c; 且 0 出现次数比 1 少, 那么这个 01 串中 0 出现了多少次? #include<iostream> #include<cmath> using namespace std;int n 23333333;int main() {//枚举 0 出现的次数//因…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

稳定币的深度剖析与展望

一、引言 在当今数字化浪潮席卷全球的时代&#xff0c;加密货币作为一种新兴的金融现象&#xff0c;正以前所未有的速度改变着我们对传统货币和金融体系的认知。然而&#xff0c;加密货币市场的高度波动性却成为了其广泛应用和普及的一大障碍。在这样的背景下&#xff0c;稳定…...

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

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

Java 二维码

Java 二维码 **技术&#xff1a;**谷歌 ZXing 实现 首先添加依赖 <!-- 二维码依赖 --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.5.1</version></dependency><de…...