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

【笔记】C语言转C++

网课链接:【C语言 转 C++ 简单教程】 https://www.bilibili.com/video/BV1UE411j7Ti/?p=27&share_source=copy_web&vd_source=4abe1433c2a7ef632aeed6a3d5c0b22a

网课老师B站id:别喷我id 

视频总时长:01:55:27

以下笔记是我通过此网课整理 建议先看完网课 再用这个笔记进行复习

网课老师同时整理了思维导图 可以在视频简介获取

/*用C++刷算法的不同之处:1、兼容C语言2、丰富的STL库3、string很好用4、时间上要差一些
*/#include<iostream>  // 输入输出流 input output
#include<cstring>  //即#include<string.h>
// C++中,C语言中的头文件都可以通过去掉.h,在开头加c实现
#include<string> 
#include<vector>
#include<set>
#include<map>
#include<stack>
#include<queue>
#include<bitset>
#include<algorithm> // sort()函数的头文件 algorithm算法
#include<cctype>
using namespace std;
// 使用名称空间 避免不同厂商使用的函数名称重复导致的误用
// 所以每家厂商将自己的函数封装在自己设定的名称空间里//结构体&引用&和传值//结构体
struct stu {string name;int age;
};
// stu a[10];  直接用stu命名变量// 引用: 引用的时候会把初始变量也改变 约等于c语言里的指针不写*
// 传值: 传值只改变函数里的变量 不会带到函数外 bool cmp1(int x, int y) {return x > y;
}
// 返回值为真 那么x放在y前面
// 返回值为假 交换两个数bool cmp2(stu a, stu b) {if (a.age != b.age)return a.age < b.age;elsereturn a.name < b.name;
}
// 以年龄为第一限制条件从小到大排序 
// 年龄相同就参考第二限制条件 按名字的ACSII码从小到大排序int main()
{//输入输出等基本int n;cin >> n;// 输入cin(记in)cout << "wohaoshuai!" << ++n << endl; // 输出cout(记out) 换行endl("\n")// cin cout的运算速度会低于scanf和printf/*若没有提前使用名称空间也可以在main函数中调用的时候使用以下格式:std::cinstd::coutstd::endl*/cout << "*******************" << endl;// bool和constfor (int i = 0; i < 10; i++)cout << n << " ";// 可在循环里定义变量icout << endl;bool flag = true;bool flag2 = -1;bool flag3 = 0;// bool将值判为0或1(非0即为1)cout << flag << " " << flag2 << " " << flag3 << endl;const int MAX = 150;// const定义的常量无法进行更改 可看做宏定义// MAX = 100; 此表达式会报错cout << MAX << endl;cout << "*******************" << endl;// 字符串// 定义字符串string s1 = "hello";string s2 = " world!";string s3 = s1 + s2;cout << s3 << endl;getline(cin, s1);// cin只能输入空格前的字符 getline可以输入一整行 但要声明头文件stringcout << s1 << endl << s1.length() << endl; // 此长度不包括\0// 子串string s1_sub = s1.substr(1, 2);// s.substr(n1,n2)(从下标为n1的字符开始,取n2个字符)// s.substr(n1)(从下标为n1的字符开始取,取完)// 【字符串下标从0开始算】cout << s1_sub << endl;cout << "*******************" << endl;// STL篇// vector 矢量向量/动态数组/不定(可变)参数组vector<int>v; // 定义一个长度为0的空数组v.resize(10);  // v.resize(length); 重新分配数组大小for (int i = 0; i < 10; i++)v[i] = i;for (int i = 0; i < 10; i++)cout << v[i] << " ";v.push_back(11); // 给数组扩充一个新空间 给首个空位赋值为11for (int i = 0; i < 11; i++)cout << v[i] << " ";cout << endl << v.size() << endl;vector<int>d(10, 2); // 定义一个长度为10,每个值都为2的数组d.size(); //变量名.方法for (auto p = d.begin(); p != d.end(); p++)  // b.end()的位置是最后一个元素的后一位cout << *p << " ";// 迭代器 自动遍历一遍数组中所有的数据cout << "*******************" << endl;// set 集合 里面的元素各不相同 而且元素会按照从小到大排序// unordered_set 省去排序过程(无序)的集合 要用#include<unordered_set>// unordered_set<int>s;  这样定义 其它调用方法和set一模一样set<int>s;s.insert(1);s.insert(2);s.insert(3);for (auto p = s.begin(); p != s.end(); p++)cout << *p << ' ';cout << endl;cout << (s.find(2) != s.end()) << endl;// 集合中找2 找到后返回2的位置 和s.end()的位置不同即返回1 说明找到了cout << (s.find(4) != s.end()) << endl;// 集合中找4 找到后返回4的位置 和s.end()的位置相同即返回0 说明未找到s.erase(1);  // 删除1cout << (s.find(1) != s.end()) << endl;cout << "*******************" << endl;// map 键值对 自动将所有的键值对按照键(ASCII)从小到大排序// unordered_map 省去排序过程(无序)的键值对 要用#include<unordered_map>// unordered_map<int>m;  这样定义 其它调用方法和map一模一样map<string, int>m;m["hello"] = 2;m["world"] = 3;m["ilovewuhan"] = 5;m["ha"] = 6;/*struct{string key;int data;}*/cout << "hello:" << m["hello"] << endl;for (auto p = m.begin(); p != m.end(); p++)cout << p->first << ":" << p->second << endl;// p->first为键 p->second为值cout << "map的长度为:" << m.size() << endl; // size容器cout << "*******************" << endl;// 栈和队列// stack 栈stack<int>sta;sta.push(1);sta.push(2);sta.push(3);sta.pop();sta.push(76);cout << sta.top() << endl;cout << "栈的长度为:" << sta.size() << endl;// 无法使用迭代器 栈只能获得栈顶元素// queue 队列queue<int>q;for (int i = 1; i <= 10; i++)q.push(i);q.pop();cout << "队首为:" << q.front() << endl << "队尾为:" << q.back() << endl;cout << q.size() << endl;cout << "*******************" << endl;// bitset 字符数组 从二进制的低位到高位依次为b[0]、b[1]……bitset<5>b(19);  // 5个二进制位 将19转化为二进制 即10011// bitset<5>b; 即初始化为00000// bitset<5>b("11"); 直接赋二进制的值 即为00011cout << b << endl; //直接输出这个字符for (int i = 0; i < b.size(); i++)cout << b[i] << " ";// 从低位到高位一个一个输出cout << endl;cout << "是否有1:" << b.any() << endl;cout << "是否不存在1:" << b.none() << endl;cout << "1的个数:" << b.count() << endl;cout << "b中元素个数:" << b.size() << endl;cout << "下标为i的元素是不是1:" << b.test(0) << endl;b.flip(1); // 第1位取反(是从右边开始数的第0位、第1位)// b.flip() 所有位取反b.reset(2); // 第2位归零// b.reset() 所有位归零cout << b << endl;unsigned long z = b.to_ulong(); // 转化为十进制cout << z << endl;string e = "0110101";bitset<5>c(e, 0, 5); // bitset<二进制位数>c(字符串,位置,取的位数)// 即bitset<5>c("01101");cout << "*******************" << endl;// sort函数 对一个数组进行排序(默认从小到大)// vector是容器 需要用v.begin()表示头 v.end()表示尾// int arr[]使用arr表示数组的首地址 arr+n表示尾部vector<int>g(10);for (int i = 9; i >= 0; i--)g[i] = 9 - i;for (int i = 0; i < 10; i++)cout << g[i] << " ";cout << endl;g.push_back(-1);sort(g.begin(), g.end()); // [ ) 左闭右开for (int i = 0; i < 11; i++)cout << g[i] << " ";cout << endl;sort(g.begin(), g.end(), cmp1); // cmp 自定义排序规则(需另外定义函数)for (int i = 0; i < 11; i++)cout << g[i] << " ";cout << endl;stu a[10];for (int i = 0; i < 10; i++)cin >> a[i].name >> a[i].age;sort(a, a + 10, cmp2);for (int i = 0; i < 10; i++)cout << a[i].name << " " << a[i].age << endl;cout << "*******************" << endl;// cctype头文件的函数char f = 'A';cout << "isalpha" << isalpha(f) << endl; // 字母?cout << "islower" << islower(f) << endl; // 小写字母?cout << "isupper" << isupper(f) << endl; // 大写字母?cout << "isalnum" << isalnum(f) << endl; // 字母or数字?cout << "isspace" << isspace(f) << endl; // space \t \r \n?char f1 = tolower(f); // 转化为小写字母cout << f1 << endl;char f2 = toupper(f); // 转化为大写字母cout << f2 << endl;cout << "*******************" << endl;// C++11篇// C++11的解释:2011年官方带来的新的语法标准 新增了很多特性   // dev c++使用C++11里的函数需要设置 // Settings->Compiler->C++11那一行勾选上->OK// auto声明  可以让编译器根据初始值直接推断变量的类型auto x = 19;auto y = 1.8;// 用auto定义的时候一定要初始化赋值// 迭代器用到auto(可用迭代器的有vector set map)// 基于范围的for循环int k[5] = { 1 };for (int i : k) // i作为参数不会带出for循环 类似于函数 除非给i改成&i取地址i++;for (int i : k)cout << i << " ";cout << endl;vector<int>k2(10, 1);for (auto i : k2) // 相当于迭代器 所有的容器都可以通过这种方式循环cout << i << " ";cout << endl;// to_string 将数字转化为字符变量string o = to_string(123.1); // 这边浮点型会自动保留到小数点后六位cout << o << endl;printf("%s\n", o.c_str()); // printf输出的形式// stoi和stod 将字符串转化为其它变量// 记忆方法:stoi (string to int)   stod (string to double) // 还有stof stold stol stoll stoul stoull等一系列int r = stoi("123");cout << r << endl;double t = stod("12.34");cout << t << endl;return 0;
}

相关文章:

【笔记】C语言转C++

网课链接&#xff1a;【C语言 转 C 简单教程】 https://www.bilibili.com/video/BV1UE411j7Ti/?p27&share_sourcecopy_web&vd_source4abe1433c2a7ef632aeed6a3d5c0b22a 网课老师B站id:别喷我id 视频总时长&#xff1a;01:55:27 以下笔记是我通过此网课整理 建议先…...

Python 单例模式工厂模式和classmethod装饰器

前言&#xff1a; Python作为面向对象的语言&#xff0c;显然支持基本的设计模式。也具备面向对象的语言的基本封装方法&#xff1a;属性、方法、继承、多态等。但是&#xff0c;做为强大的和逐渐发展的语言&#xff0c;python也有很多高级的变种方法&#xff0c;以适应更多的…...

源码编译构建LAMP

源码编译构建LAMP 文章目录 源码编译构建LAMPLAMPDISCUZ论坛 1.安装编译工具等2.apache3.mysql4.php5.部署论坛网站6.其他6.其他 LAMPDISCUZ论坛 1.安装编译工具等 安装说明&#xff1a; 配置yum源 从阿里云下载新的配置文件 curl -o /etc/yum.repos.d/CentOS-Base.repo htt…...

如何让verilog支持二维数组,三维数组作为I/O ports

写在前面 先看看verilog中的一维数组&#xff0c;二维数组&#xff0c;三维数组长啥样&#xff1f; wire [31:0]data1;//一维数组 wire [31:0]data2 [0:15];//二维数组 wire [31:0]data3 [0:15][0:15];//三维数组众所周知&#xff0c;verilog只支持一维数组作为I/O ports&…...

字符编码讲解(C#)

在学习和编码的过程中&#xff0c;极容易遇到如下概念&#xff0c;他们有些是字符编码&#xff0c;有些是涉及的相关概念&#xff0c;接下来我将围绕下面的熟悉又陌生的概念做详细解释&#xff0c;并且梳理其之间的关系 UTF8&#xff0c; Unicode &#xff0c;ASCII&#xff0…...

Unreal Engine 中的UI界面开发

推荐的使用方式 轻量级 HUD&#xff1a;使用 Canvas 绘制简单的文本、调试信息或基础 UI&#xff08;如准星、血量条等&#xff09;。 复杂 UI&#xff1a;使用 UMG&#xff08;Unreal Motion Graphics&#xff09;和 Slate 进行布局和交互&#xff0c;避免手动管理 Canvas 绘制…...

聚类及Python下实现 K-means 算法

聚类 聚类是无监督学习中的一种重要方法&#xff0c;旨在将数据集中相似的数据对象划分到同一个簇中&#xff0c;使得不同簇之间的数据对象差异尽可能大。在大数据环境下&#xff0c;聚类可以帮助挖掘数据中的隐藏结构和模式&#xff0c;应用场景十分广泛&#xff0c;比如在客…...

【中间件开发】Redis基础命令详解及概念介绍

文章目录 前言一、Redis相关命令详解及原理1.1 string、set、zset、list、hash1.1.1 string1.1.2 list1.1.3 hash1.1.4 set1.1.5 zset 1.2 分布式锁的实现1.3 lua脚本解决ACID原子性1.4 Redis事务的ACID性质分析 二、Redis协议与异步方式2.1 Redis协议解析2.1.1 redis pipeline…...

分布式文件存储 - - - MinIO从入门到飞翔

MinIO从入门到飞翔 文章目录 MinIO从入门到飞翔 0、前言1、分布式文件系统2、MinIO 介绍3、 MinIO安装&#xff08;docker&#xff09;4、基本概念5、通过代码上传文件到MinIO6、封装MinIO为starter7、在其他项目中集成封装好的模块 0、前言 对象存储是一种数据存储架构&a…...

Cadence学习笔记 1 原理图库绘制

基于Cadence 17.4&#xff0c;四层板4路HDMI电路 目录 一、原理图绘制及封装制作 1、原理图库绘制简介 一、原理图绘制及封装制作 1、原理图库绘制简介 File--Change Product&#xff0c;选择OrCAD Capture CIS。绘制原理图和原理图库都是用CIS完成 更改界面颜色&#xff1a…...

Unity 制作一个视频播放器(打包后,可在外部编辑并放置新的视频)

效果展示&#xff1a; 在这里&#xff0c;我把视频名称&#xff08;Json&#xff09;和对应的视频资源都放在了StreamingAssets文件夹下&#xff0c;以便于打包后&#xff0c;客户还可以自己在外部增加、删除、修改对应的视频资料。 如有需要&#xff0c;请联细抠抠。...

python爬虫--小白篇【爬虫实践】

一、前言 1.1、王者荣耀皮肤爬虫 根据王者荣耀链接&#xff0c;将王者荣耀的全部英雄的全部皮肤图片爬取保存到本地。经过分析得到任务的三个步骤&#xff1a; 根据首页全部英雄列表连接获取全部英雄的名称hero_name以及对应的hero_id&#xff1b;根据单个英雄的hero_name和h…...

CountDownLatch阻塞后countDown未执行会如何?

背景 某项目封装了 Kafka 消费者 API&#xff0c;根据传递的消费者线程数&#xff0c;创建 N 个消费者线程同时消费对应 topic 的数据&#xff0c;并在线程启动后收集到全局列表中&#xff0c;方便在程序调用 stop 流程时逐个停止。 主控类在创建 Kafka 消费线程时使用了 Cou…...

《MySQL 查询进阶:复杂查询语句的魅力》

一、引言 MySQL 的复杂查询语句就像是一把神奇的钥匙&#xff0c;能够打开数据世界的大门&#xff0c;展现出数据的无限魅力。本文将带你深入探索 MySQL 查询进阶技巧&#xff0c;从常用查询到子查询&#xff0c;再到视图的运用&#xff0c;让你领略复杂查询语句的强大功能。 …...

Vue解决跨域问题

要解决 Vue 项目的跨域问题并通过 vue.config.js 配置代理&#xff0c;可以按照以下步骤修改 vue.config.js 文件。你提供的代码大部分已经正确&#xff0c;只需要做一些格式上的调整。以下是正确的 vue.config.js 配置&#xff1a; // vue.config.jsmodule.exports {devServ…...

大语言模型(LLM)与智能机器人的应用分析

系列文章目录 前言 近年来,大型语言模型(LLM)的集成彻底改变了机器人领域,使机器人能够以人类熟练程度进行交流、理解和推理。本文探讨了 LLM 对机器人的多方面影响,并针对在不同领域利用这些模型的关键挑战和机遇进行了研究。通过将 LLM 应用程序分类并分析核心机器人元素…...

String【Redis对象篇】

&#x1f3c6; 作者简介&#xff1a;席万里 ⚡ 个人网站&#xff1a;https://dahua.bloggo.chat/ ✍️ 一名后端开发小趴菜&#xff0c;同时略懂Vue与React前端技术&#xff0c;也了解一点微信小程序开发。 &#x1f37b; 对计算机充满兴趣&#xff0c;愿意并且希望学习更多的技…...

Elasticsearch高性能实践

前言 本方案主要从运维层面分析es是实际生产使用过程中的参数优化&#xff0c;深入理解es各个名词及含义&#xff0c;深入分析es的使用过程中应注意的点&#xff0c;详细解释参数设置的原因以及目的&#xff0c;主要包括系统层面&#xff0c;参数层面。除此之外&#xff0c;优…...

Maven 安装配置(详细教程)

文章目录 一、Maven 简介二、下载 Maven三、配置 Maven3.1 配置环境变量3.2 Maven 配置3.3 IDEA 配置 四、结语 一、Maven 简介 Maven 是一个基于项目对象模型&#xff08;POM&#xff09;的项目管理和自动化构建工具。它主要服务于 Java 平台&#xff0c;但也支持其他编程语言…...

sql server 创建索引实验

创建一个非主键索引&#xff0c;大小30G&#xff0c;数据文件增加了30G&#xff0c;日志文件增长了50G,4分钟完成&#xff0c; &#xff08;日志文件增加设置为2048MB 或者 256MB 执行时间都是4分钟&#xff0c;没有多大的时间差异&#xff09; 实验环境&#xff1a; 主机cpu…...

解决Vue项目中npm install卡住问题的详细指南

解决Vue项目中npm install卡住问题的详细指南 引言 在开发Vue项目时&#xff0c;我们经常会遇到npm install命令卡住的问题&#xff0c;特别是在构建依赖树时。本文将分享一些实用的解决方案&#xff0c;帮助您快速解决这一常见问题。 问题描述 在执行npm install时&#xf…...

手机实时提取SIM卡打电话的信令声音--社会价值(一、方案解决了什么问题)

手机实时提取SIM卡打电话的信令声音 --社会价值(一、方案解决了什么问题) 一、前言 这段时间&#xff0c;我们在技术范围之外陷入了一个自证或者说下定义的怪圈&#xff0c;即要怎么样去介绍或者描述&#xff1a;我们是一个什么样的产品。它在当前这个世界上&#xff0c;处于…...

35.1 thanos项目介绍和二进制部署

本节重点介绍 : 核心优点 无需维护存储&#xff0c;存储高可用&#xff1a; 利用廉价的公有云对象存储&#xff0c;高可用长时间存储&#xff0c;数据降采样&#xff1a;利用Compactor降采样完全适配原生prometheus查询接口&#xff1a;Query实现多级数据缓存配置 二进制部署 …...

【中工开发者】鸿蒙商城实战项目(启动页和引导页)

创建一个空项目 先创建一个新的项目选择第一个&#xff0c;然后点击finish 接下来为项目写一个名字&#xff0c;然后点击finish。 把index页面的代码改成下面代码块的代码&#xff0c;就能产生下面的效果 Entry Component struct Index {build() {Column(){Blank()Column(){…...

云计算IaaS-PaaS-SaaS三种服务模式转至元数据结尾

在当今数字化时代&#xff0c;云计算已经成为推动企业创新与发展的核心力量。而云计算的模型主要有三种&#xff1a;IAAS、PAAS 和 SAAS&#xff0c;它们各自在云计算的庞大体系中扮演着独特且关键的角色&#xff0c;恰似一座大厦的不同楼层&#xff0c;共同构建起强大而灵活的…...

Python爬虫:如何优雅地“偷窥”商品详情

在这个信息爆炸的时代&#xff0c;获取商品详情已经不再是简单的点击和浏览。我们需要的是速度、效率&#xff0c;还有一点点的...偷偷摸摸。没错&#xff0c;今天我们要聊的是如何使用Python爬虫来“偷窥”商品详情。别担心&#xff0c;我们保证一切都是合法合规的&#xff0c…...

自动化测试报错:Exception managing chrome: error decoding response body

报错&#xff1a;Exception managing chrome: error decoding response body 报错解释&#xff1a; 这个错误通常发生在使用Selenium WebDriver时&#xff0c;尝试管理&#xff08;例如关闭&#xff09;Chrome浏览器时出现了问题。具体来说&#xff0c;是在解码Chrome浏览器响…...

Dataset 与 JavaRDD

是的&#xff0c;Dataset 底层确实是基于 RDD 实现的&#xff0c;但它是通过更高层次的抽象和优化来提供更强大和易用的功能。以下是关于 Dataset 底层实现的一些详细信息&#xff1a; 1. RDD 是基础 RDD&#xff08;弹性分布式数据集&#xff09; 是 Spark 最基础的抽象&…...

【后端面试总结】Golang defer的实现原理和常见面试问题

前言 在Go语言中&#xff0c;defer关键字用于延迟函数的执行&#xff0c;即在包含defer语句的函数返回之前执行。这一特性使得defer在资源释放、文件关闭、解锁资源等场景中非常有用。本文将深入探讨defer的实现原理&#xff0c;并总结一些常见的面试问题。 基本使用 defer通…...

http 502 和 504 的区别

首先看一下概念&#xff1a; 502&#xff1a;作为网关或者代理工作的服务器尝试执行请求时&#xff0c;从上游服务器接收到无效的响应。503&#xff1a;由于临时的服务器维护或者过载&#xff0c;服务器当前无法处理请求。这个状况是临时的&#xff0c;并且将在一段时间以后恢…...

农业园区气象站

农业园区气象站是一种专为农业生产和科研设计的气象监测设备&#xff0c;它集成了多种传感器和技术&#xff0c;用于实时、准确地监测和记录农业园区内的气象数据。以下是农业园区气象站的主要功能和用处&#xff1a; 一、主要功能 实时监测&#xff1a;农业园区气象站能够实时…...

机器学习学习笔记-20241211

文章目录 空间归纳偏置局部性&#xff08;Locality&#xff09;平移不变性&#xff08;Translation Invariance&#xff09;空间关系&#xff08;Spatial Relationships&#xff09;尺度不变性&#xff08;Scale Invariance&#xff09;上下文依赖&#xff08;Context Dependen…...

【在Linux世界中追寻伟大的One Piece】HTTP Session

目录 1 -> 引入HTTP Session 1.1 -> 定义 1.2 -> 工作原理 1.3 -> 安全性 1.4 -> 超时和失效 1.5 -> 用途 2 -> 模拟session行为 3 -> 实验测试session 1 -> 引入HTTP Session 1.1 -> 定义 HTTP Session是服务器用来跟踪用户与服务器交…...

人工智能|自然语言处理——机器翻译评价指标Bleu和Rouge

在机器翻译任务中&#xff0c;BLEU 和 ROUGE 是两个常用的评价指标&#xff0c;BLEU 根据精确率(Precision)衡量翻译的质量&#xff0c;而 ROUGE 根据召回率(Recall)衡量翻译的质量 BLEU&#xff08;Bilingual Evaluation Understudy&#xff09;&#xff1a; BLEU是一种用于评…...

【前端】JavaScript中的函数形式参数:预解析与作用域详解

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: 前端 文章目录 &#x1f4af;前言&#x1f4af;示例代码&#x1f4af;1. 形式参数的预解析模拟预解析后的代码 &#x1f4af;2. 函数作用域与子函数的关系代码详解 &#x1f4af;3. 扩展&#xff1a;块作用域与变量提…...

自然语言处理的未来愿景

自然语言处理的未来愿景 在这个信息爆炸的时代,计算机如何理解和生成我们日常使用的语言,已经成为一个引人注目的问题。你有没有想过,为什么智能助手能理解你的指令?又或者,为什么社交媒体上的推荐引擎能够精准地推荐你喜爱的内容?这背后,正是自然语言处理(NLP)在发挥…...

Vmodel环境配置

1.conda create -n pytorch311 python3.11 # 重新进入虚拟环境 source activate # 退出虚拟环境 conda deactivate 最后&#xff0c;重新执行 conda activate pytorch311 pip install torch-2.0.0cpu-cp311-cp311-linux_x86_64 配置Graph-WaveNet网络&#xff1a; pip…...

nvm-windows | node版本管理

问题&#xff1a; npm ERR! notsup Not compatible with your version of node/npm: npm10.9.2 npm ERR! notsup Required: {"node":"^18.17.0 || >20.5.0"} npm ERR! notsup Actual: {"npm":"9.5.0","node":"v18.…...

GLM-4V-Flash:智谱AI引领多模态视觉模型新潮流

点击访问 chatTools 免费体验GPT最新模型&#xff0c;包括o1推理模型、GPT4o 和Claude等模型&#xff01; 随着人工智能技术的不断进步&#xff0c;多模态模型逐渐成为行业关注的焦点。智谱AI作为国内领先的人工智能公司&#xff0c;再次以创新姿态推出了首款免费多模态视觉模型…...

二、ubuntu单盘改软raid1

将单盘系统转换为软 RAID 1 是一个复杂的过程&#xff0c;尤其是在已经有数据的生产环境中进行时。这个过程涉及备份现有数据、创建 RAID 阵列、迁移数据以及更新引导加载程序&#xff08;如 GRUB&#xff09;。以下是详细的步骤指南&#xff1a; 前提条件 备份数据&#xff…...

「Mac玩转仓颉内测版45」小学奥数篇8 - 排列组合计算

本篇将通过 Python 和 Cangjie 双语讲解如何计算排列与组合。这道题目旨在让学生学会使用排列组合公式解决实际问题&#xff0c;并加深对数学知识和编程逻辑的理解。 关键词 小学奥数Python Cangjie排列与组合 一、题目描述 编写一个程序&#xff0c;计算从 n 个不同元素中取…...

【零成本抽象】基本概念与在C++中的实现

零成本抽象概念是由 Bjarne Stroustrup 提出的,他在 1994 年的著作中就有相关设想,2016 年其在 C++ 大会登台演讲时,明确阐述了 C++ 中的 “零成本抽象” 这一理念。 一、零成本抽象概念 Bjarne Stroustrup提出的零成本抽象概念,是指在编程中使用高级抽象机制时,不会产生…...

域渗透入门靶机之HTB-Cicada

easy难度的windows靶机 信息收集 端口探测 nmap -sT --min-rate 10000 -p- 10.10.11.35 -oA ./port 发现开放了53&#xff0c;88&#xff0c;389等端口&#xff0c;推测为域控 进一步信息收集&#xff0c;对爆破的端口进行更加详细的扫描 小tips&#xff1a;对于众多的端口&…...

(仓颉) Cangjie 刷力扣基础语法小结

文章目录 &#x1f9d3;官方资料&#x1f9d3;力扣经典前 3 题&#x1f577;️[1. 两数之和 - 力扣&#xff08;LeetCode&#xff09;](https://leetcode.cn/problems/two-sum/description/)&#x1f577;️[2. 两数相加 - 力扣&#xff08;LeetCode&#xff09;](https://leet…...

Phoenix5.1.3安装

环境说明 准备三台服务器&#xff0c;分别为&#xff1a;bigdata141&#xff08;作为HBase主节点&#xff09;、bigdata142、bigdata143&#xff0c;已经搭建好HBase集群&#xff0c;我这边HBase版本为2.2.7再准备一台服务器&#xff0c;bigdata144&#xff0c;可作为Phoenix客…...

深入理解 Apache Shiro:安全框架全解析

亲爱的小伙伴们&#x1f618;&#xff0c;在求知的漫漫旅途中&#xff0c;若你对深度学习的奥秘、JAVA 、PYTHON与SAP 的奇妙世界&#xff0c;亦或是读研论文的撰写攻略有所探寻&#x1f9d0;&#xff0c;那不妨给我一个小小的关注吧&#x1f970;。我会精心筹备&#xff0c;在…...

机器学习:全面学习路径指南

摘要&#xff1a; 本文精心规划了一条从入门到精通机器学习的学习路线&#xff0c;详细涵盖了基础理论构建、核心技术栈掌握、主流算法学习、实践项目锻炼以及前沿领域探索等多个关键阶段。通过逐步深入各个层面&#xff0c;介绍必备的数学知识、编程工具、经典与现代机器学习算…...

二叉树交换相关算法题|递归/非递归交换所有节点左右子树(C)

交换左右子树 设树B是一棵采用链式结构存储的二叉树&#xff0c;编写一个把树B中所有节点的左右子树进行交换的函数 算法思想 采用递归算法实现交换二叉树的左右子树&#xff0c;首先交换root节点左孩子的左右子树&#xff0c;然后交换root节点右孩子的左右子树&#xff0c;…...

什么是纯虚函数?什么是抽象类?纯虚函数和抽象类在面向对象编程中的意义是什么?

纯虚函数 纯虚函数是一个在基类中声明但不实现的虚函数。它的声明方式是在函数声明的末尾添加 0。这意味着这个函数没有提供具体的实现&#xff0c;任何继承这个基类的派生类都必须提供这个函数的实现&#xff0c;否则它们也会变成抽象类&#xff0c;无法实例化。 示例&#…...

高效利用资源:分布式有状态服务的高可靠性设计

在分布式系统设计中&#xff0c;实现有状态服务的高可靠性通常采用主备切换的方式。当主服务停止工作时&#xff0c;备服务接管任务&#xff0c;例如通过Keepalive实现VIP的切换以保证可用性。然而&#xff0c;这种方式存在资源浪费的问题&#xff0c;因为备服务始终处于空转状…...