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

uniapp 对接腾讯云IM群组成员管理(增删改查)

UniApp 实战&#xff1a;腾讯云IM群组成员管理&#xff08;增删改查&#xff09; 一、前言 在社交类App开发中&#xff0c;群组成员管理是核心功能之一。本文将基于UniApp框架&#xff0c;结合腾讯云IM SDK&#xff0c;详细讲解如何实现群组成员的增删改查全流程。 权限校验…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

Docker 离线安装指南

参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性&#xff0c;不同版本的Docker对内核版本有不同要求。例如&#xff0c;Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本&#xff0c;Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

基于大模型的 UI 自动化系统

基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...

(十)学生端搭建

本次旨在将之前的已完成的部分功能进行拼装到学生端&#xff0c;同时完善学生端的构建。本次工作主要包括&#xff1a; 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...

pam_env.so模块配置解析

在PAM&#xff08;Pluggable Authentication Modules&#xff09;配置中&#xff0c; /etc/pam.d/su 文件相关配置含义如下&#xff1a; 配置解析 auth required pam_env.so1. 字段分解 字段值说明模块类型auth认证类模块&#xff0c;负责验证用户身份&am…...

Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理

引言 Bitmap&#xff08;位图&#xff09;是Android应用内存占用的“头号杀手”。一张1080P&#xff08;1920x1080&#xff09;的图片以ARGB_8888格式加载时&#xff0c;内存占用高达8MB&#xff08;192010804字节&#xff09;。据统计&#xff0c;超过60%的应用OOM崩溃与Bitm…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

STM32---外部32.768K晶振(LSE)无法起振问题

晶振是否起振主要就检查两个1、晶振与MCU是否兼容&#xff1b;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容&#xff08;CL&#xff09;与匹配电容&#xff08;CL1、CL2&#xff09;的关系 2. 如何选择 CL1 和 CL…...