蓝桥杯备赛:C++基础,顺序表和vector(STL)

目录

一.C++基础

1.第一个C++程序:

2.头文件:

3.cin和cout初识:

4.命名空间:

二.顺序表和vector(STL)

1.顺序表的基本操作:

2.封装静态顺序表:

3.动态顺序表--vector:

(1)创建vector:

(2)size和empty:

(3)begin和end:

(4)front和back:

(5)resize和clear:


一.C++基础

1.第一个C++程序:

可能有些同学跟我一样,一直以来学习的都是基础的C语言,而在接触蓝桥杯这类相比较正规的竞赛时会发现它所使用的程序规范与基础的C语言大相径庭,但没关系的,虽然他使用的规范隶属于C++范畴,但只要掌握以下几条差异,C++于我们也不会再陌生,光说不算,先直接来看一下我们的第一个C++程序:

​
#include <iostream> //头⽂件 
using namespace std; //使⽤std的名字空间 
int main() //main函数 
{cout << "hello world!" << endl; //输出:在屏幕打印"hello world!" return 0;
}

2.头文件:

ok,接下来我就来详细说说这其中的一些区别,当然最先注意到的就是包含的头文件的差异了:

        前⾯的代码中,写的 #include ,就是在包含头⽂件,头⽂件的名字叫: iostream

使用 #include <> 的形式进行包含

        iostream 文件中的 io 指的是输⼊(进入程序的信息,简单理解就是可以给程序输⼊数据)和输出(从程序中输出的信息,简单理解就是程序 会打印数据在屏幕上)。

        在 C++ 程序中要完成输⼊和输出的操作会涉及到 iostream 文件中的多个定义,所以就要包含这个 头⽂件的

        比如:代码中的 cout 是输出流对象,就是⽤来完成数据输出的,就需要包含头文件。

简单些理解:iostream这个头文件就当于是一个我们之前学习C语言里无数头文件的一个集合,为的就是使我们对头文件的包含的使用更加方便和简洁

注:

        1. 在C语⾔中头文件的扩展名是 .h ,但是C++中的⽤法发生了⼀些变化,对⽼式C的头⽂件保留了扩展名 .h ,但是C++自己的⽂件没有扩展名了,如原来的C语⾔头⽂件: 

        2. 有些C的头⽂件被转换成C++头⽂件,这些⽂件名被重命名,去掉了.h扩展名,并在⽂件名的前⾯加 上了前缀c(表示来⾃C语⾔);例如:C语⾔中有关数学的头⽂件名字是 math.h ,在C++中就 是 cmath ,当然还得注意,有时头⽂件的C语⾔版本和C++版本相同,⽽有时候,新版本做了⼀些 修改:

3.cin和cout初识:

cout << "hello world!" << endl;这句代码在上⾯的程序中是最重要的代码,其他所有的 代码都是为了编写这句代码。

cout标准输出流对象(针对控制台,也就是屏幕),其实还有标准输⼊流对象cin(针对的是键 盘)

即cout 告诉程序把后⾯双引号中的内容打印到标准输出设备(屏幕)上,双引号中的内容可以替换

#include<iostream>
using namespace std;
int main()
{int num;cin >> num; //获取标准输⼊ cout << num << endl; //对获取到的结果标准输出 return 0;
}

总结:

1.cin 和 cout 是全局的流对象, cin 负责输⼊数据(scanf)cout 负责输出数据(printf)

2. endl 是C++中⼀个特殊的操作符,效果是换行和刷新缓冲区,使⽤时必须包含在 iostream 头文件里

3. <<是流插⼊运算符,和 cout 配合使用, >> 是流提取运算符,和 cin 配合使⽤,两者容易混 淆,⼤家⼀定要仔细区分,不可混用

使⽤C++输⼊输出更⽅便,不需要像 printf / scanf 输⼊输出时那样,需要⼿动控制格式。 C++的输⼊输出可以⾃动识别变量类型。(后面会提到到,慢慢体会就好):

#include <iostream>
using namespace std;
int main() 
{float score = 0;cin >> score;//直接读取的就是浮点数 cout << score;//直接输出的就是浮点数 return 0;
}

4.命名空间:

using namespace std; 这句代码的意思是:使⽤名字空间 std (名字空间也叫命名空间), 为了理解什么是名字空间,名字空间要解决什么问题,先看⼀下下面的例子:

在C++中,变量、函数和类都是⼤量存在的,这些变量、函数和类的名称如果都存在于全局作⽤域中, 可能会导致很多冲突。使⽤ 名字空间 的⽬的是对标识符的名称进⾏隔离,以避免命名冲突或名字污染, namespace 关键字的出现就是针对这种问题的。 std 是C++标准库的名字空间名,C++将标准库的定义实现都放到这个命名空间中,当我们需要使用标准库中的内容时,就需要加上: using namespace std ;当有了这句代码的时候,表示命名空间 std 中信息都是可见和可⽤的,比如: cin 、 cout 、 endl 等:

当然使用using namespace std;是⼀种简单粗暴的做法,直接这样使⽤,就意味着后续在std这个名字空间中的各种定义都可以直接使⽤,但是我们往往只是使⽤部分。所以名字空间其实也可以这样使⽤

#incldue <iostream>
int main()
{   std::cout << "hello world" << std::endl;return 0;
}

代码中的 std::cout的意思就是使⽤std名字空间中的cout

欧克,到这里为止再看一下最初的C++程序,是不是就好理解多了:

#include <iostream> //头⽂件 
using namespace std; //使⽤std的名字空间 
int main() //main函数 
{cout << "hello world!" << endl; //输出:在屏幕打印"hello world!" return 0;
}

二.顺序表和vector(STL)

说完了上面C++的基础格式,接下来就是正式的蓝桥杯知识点的干货分享了

1.顺序表的基本操作:

其实顺序表的基本操作无非就是我们老生常谈的那几种尾插尾删,头插头删,指定位置插入和删除和对某一个元素的查找,这些在C语言基础里我都有提及,详细可以看我附在下面的这篇文章:

https://blog.csdn.net/2403_87691282/article/details/144203616?spm=1001.2014.3001.5501

方便起见,我还是把简化的一些操作附在下面,以便阅览:

// 打印顺序表 
void print()
{for(int i = 1; i <= n; i++){cout << a[i] << " ";}cout << endl << endl;
}// 尾插 
void push_back(int a[], int& n, int x)
{a[++n] = x;
}// 头插 
void push_front(int x)
{// 1. 先把 [1, n] 的元素统⼀向后移动⼀位 for(int i = n; i >= 1; i--){a[i + 1] = a[i];}// 2. 把 x 放在表头 a[1] = x;n++; // 元素个数 +1 
}// 在任意位置插⼊ 
void insert(int p, int x)
{//把 [p, n] 的元素统⼀向后移动⼀位 for(int i = n; i >= p; i--){a[i + 1] = a[i];}a[p] = x;n++;
}// 尾删 
void pop_back()
{n--;
}// 头删 
void pop_front()
{// 1. 先把 [2, n] 区间内的所有元素,统⼀左移⼀位 for(int i = 2; i <= n; i++){a[i - 1] = a[i];}n--;
}// 任意位置删除 
void erase(int p)
{// 把 [p + 1, n] 的元素,统⼀左移⼀位 for(int i = p + 1; i <= n; i++){a[i - 1] = a[i];}n--;
}// 按值查找 
int find(int x)
{for(int i = 1; i <= n; i++){if(a[i] == x) return i;}return 0;
}// 按位查找 
int at(int p)
{return a[p];
}// 按位修改 
int change(int p, int x)
{a[p] = x;
}// 清空操作 
void clear()
{n = 0;
}

2.封装静态顺序表:

所谓封装静态顺序表就是当我们在面对需要创建好几个顺序表并且对它们进行操作及以下情况时而产生的简化操作的行为:

可见,当涉及到多个顺序表时,虽然上述的代码可以套用,但还是略显麻烦,这个时候就不由得发问了:博主博主,这些函数固然好用,但有没有什么其他更简便的套用方式,有的兄弟,有的,这么方便的用法当然是有的:

#include <iostream>
using namespace std;
const int N = 1e5 + 10;
// 将顺序表的创建以及增删查改封装在⼀个类中 
class SqList
{int a[N];int n;
public:// 构造函数,初始化 SqList(){n = 0;}// 尾插 void push_back(int x){a[++n] = x;}// 尾删 void pop_back(){n--;}// 打印 void print(){for (int i = 1; i <= n; i++){cout << a[i] << " ";}cout << endl;}
};
int main()
{SqList s1, s2; // 创建了两个顺序表 for (int i = 1; i <= 5; i++){// 直接调⽤ s1 和 s2 ⾥⾯的 push_back s1.push_back(i);s2.push_back(i * 2);}s1.print();s2.print();for (int i = 1; i <= 2; i++){s1.pop_back();s2.pop_back();}s1.print();s2.print();return 0;
}

在上述代码里,博主使用了class(类的运用)对几个函数进行封装,这样在以后对顺序表的操作时,就可以直接使用”.“进行各种简洁的运用了

当然这里还需再提一下class和public的使用了(蓝桥杯作为一个应试考试,好些代码的具体原理就不再在这里进行深究了,未来我会具体介绍,但也仅供了解):

在C++中,‌class是定义类的关键字,而public是访问修饰符之一‌

以下是详细解释:

‌class(类)‌

类是C++中的基本构造块,用于定义对象的属性和行为‌
类使用class关键字声明,后面跟着类名和类体,类体中包含成员变量和成员函数‌2。
‌public(公有)‌

public是类的访问修饰符之一,表示该成员(变量或函数)是公有的,可以被类的外部访问‌
公有成员在类的内部和外部都可以被访问,相当于C语言中的struct结构体成员‌

ps

在C++中,类和结构体(struct)都是用于定义复合数据类型的构造,它们都可以包含成员变量和成员函数。然而,尽管它们在许多方面相似,但也有一个关键的区别:

即默认访问权限‌

‌类(class)‌:在类中,默认的访问权限是私有的(private),这意味着除非明确指定为public或protected,否则类的成员是不可从类外部访问的。
结构体(struct)‌:在结构体中,默认的访问权限是公有的(public),这意味着结构体的所有成员默认都是可以从外部访问的,除非它们被明确指定为private或protected

当然我这边讲封装肯定不仅仅是为了简洁,更多的还是为我接下来介绍SYL做一个铺垫

当然STL具体是啥我还是先说明一下:

提供高效的数据结构‌:
STL包含了多种高效的数据结构,如vector(动态数组)、list(双向链表)、map(映射/字典)、set(集合)等。这些数据结构都是经过精心设计和优化的,可以在不同的场景下提供高效的数据存储和访问。

‌实现常用的算法‌:
STL提供了一系列常用的算法,如排序、搜索、合并、拷贝等。这些算法都是以模板函数的形式提供的,可以适用于不同的数据类型和容器。通过使用STL的算法,可以避免重复编写常见的算法代码,提高开发效率。

3.动态顺序表--vector:

       在之前C语言的学习过程中,一提到动态顺序表就不由得会回忆起被malloc和free,new和deletae支配的恐惧,而这里需要强调一点的就是竞赛代码不同于我们之前学的工程代码,什么是工程代码,就是以malloc为首的一系列相比来说在竞赛中使用效率不高而且容易超时的一系列函数,因此当我们在竞赛过程中使用动态顺序表的时候就有了一种更好的方式:

       C++ 的STL 提供了⼀个已经封装好的容器vector , 有的地⽅也叫作变⻓数组, vector 的底层就是⼀个会⾃动扩容的顺序表,其中创建以及增删查 改等等的逻辑已经实现好了,并且也完成了封装, 接下来就重点了解以下vector 的使用:

(1)创建vector:
#include <vector> // 头⽂件 
using namespace std;
const int N = 20;
struct node
{int a, b, c;
};
// 创建 
void init()
{vector<int> a1; // 创建⼀个空的可变⻓数组 vector<int> a2(N); // 指定好了⼀个空间,⼤⼩为 N vector<int> a3(N, 10); // 创建⼀个⼤⼩为 N 的 vector,并且⾥⾯的所有元素都是 10 vector<int> a4 = { 1, 2, 3, 4, 5 }; // 使⽤列表初始化,创建⼀个 vector // <> ⾥⾯可以放任意的类型,这就是模板的作⽤,也是模板强⼤的地⽅ // 这样,vector ⾥⾯就可以放我们接触过的任意数据类型,甚⾄是 STL vector<string> a5; // 放字符串 vector<node> a6; // 放⼀个结构体 vector<vector<int>> a7(N); vector<int> a8[N]; 
}

大家仔细看的话会发现我最后俩没写注释,为啥,因为我觉得这俩在理解上有些不太容易,所以我就单独把它们拎出来做解释:

就正如上图(字可能有些丑,凑合看看吧(捂脸))所示,可以理解为前者的主体时vector<int>类型的变长数组,而后者则是已顺序表为主体来存放变长数组

其实在C++中,vector<vector<int>> a7(N); 和 vector<int> a8[N]; 是两种不同的方式来创建数组或数组的数组(即二维数组),但它们依旧有着本质的区别

‌vector<vector<int>> a7(N);‌

这是一个使用vector容器创建的二维动态数组。vector是C++标准模板库(STL)中的一个序列容器,它可以动态地管理内存,根据需要自动调整大小。这里的a7是一个包含N个vector<int>的vector,即一个二维数组,其中每一行都是一个可以独立调整大小的vector<int>

‌优点‌:
动态调整大小:每一行都可以根据需要独立增加或减少元素。
内存管理自动化:vector会自动管理内存,减少内存泄漏的风险。
‌缺点‌:
可能的性能开销:由于动态调整大小和自动内存管理,可能会引入一些性能开销。
不是连续内存:vector的底层实现通常是一个指向动态分配内存的指针数组,因此二维vector的元素在内存中不是连续存储的。


‌vector<int> a8[N];‌

这是一个静态数组,其中每个元素都是一个vector<int>,不同于第一个例子,这里的数组大小N必须在编译时就已知,且整个数组的大小在创建后是固定的。

‌优点‌:
可能的性能优势:由于是静态数组,其大小在编译时确定,可能在某些情况下提供更好的性能,尤其是在访问连续内存时。
‌缺点‌:
固定大小:数组的大小在创建后不能改变,这限制了其灵活性。
非标准C++:使用静态数组的方式在某些情况下可能不符合现代C++的最佳实践,尤其是在需要动态调整大小或跨函数共享数据时。
总结来说,选择哪种方式取决于具体需求,如果需要一个大小可变的二维数组,或者希望自动管理内存,那么vector<vector<int>>是一个好选择,如果知道数组的大小并且希望利用静态数组可能的性能优势,那么vector<int> a8[N];也可以考虑,不过,在现代C++编程中,推荐使用vector和智能指针等STL组件来管理动态数据结构,以减少内存管理错误和提高代码的可维护性

(2)size和empty:

1. size :返回实际元素的个数

2. empty :返回顺序表是否为空,因此是⼀个bool 类型的返回值

    a. 如果为空:返回true

    b. 否则,返回false

时间复杂度:O(1)

以下是具体使用方式,接下来我介绍的几个都是vector里常用的关键字,了解会用就行

void test_size()
{// 创建⼀个⼀维数组 vector<int> a1(6, 8);for(int i = 0; i < a1.size(); i++){cout << a1[i] << " ";}cout << endl << endl;// 创建⼀个⼆维数组 vector<vector<int>> a2(3, vector<int>(4, 5));for(int i = 0; i < a2.size(); i++){// 这⾥的 a2[i] 相当于⼀个 vector<int> a(4, 5) for(int j = 0; j < a2[i].size(); j++){cout << a2[i][j] << " ";}cout << endl;}cout << endl << endl;
}
(3)begin和end:

1. begin :返回起始位置的迭代器(左闭)

2. end :返回终点位置的下⼀个位置的迭代器(右开)

利⽤迭代器可以访问整个vector ,存在迭代器的容器就可以使⽤范围for 遍历

说到迭代器,还有一点不得不提一下我们的auto了:

在C++11及更高版本中,auto 关键字被引入以支持类型自动推导。这意味着编译器可以根据初始化表达式自动推断变量的类型,而无需指定,auto 的使用可以简化代码,尤其是在处理复杂类型或模板时:

int x = 10;
auto y = x; // y 的类型被推导为 int

当使用STL容器(如 vector, map, set 等)的迭代器时,auto 可以避免冗长的迭代器类型声明:

std::vector<int> vec = {1, 2, 3, 4};
for (auto it = vec.begin(); it != vec.end(); ++it){// it 的类型被推导为 std::vector<int>::iteratorstd::cout << *it << std::endl;}

还可以与语法糖结合在一起使用:

for (auto x : a)
{cout << x << "";
}
cout << endl;

当然这里的a是指一个vector<int>类型的变长数组

上面这两行代码都可以实现对a数组的遍历与打印

(4)front和back:

1. front :返回⾸元素

2. back :返回尾元素

时间复杂度:O(1)

//  ⾸元素和尾元素 
void test_fb()
{vector<int> a(5);for(int i = 0; i < 5; i++){a[i] = i + 1;}cout << a.front() << " " << a.back() << endl;
}

这个使用并不难,看一下了解即可

(5)resize和clear:

1.resize:修改vector 的大小

• 如果⼤于原始的大小,多出来的位置会补上默认值,⼀般是0 

• 如果⼩于原始的大小,相当于把后⾯的元素全部删掉。 时间复杂度:O(N) 

2.clear:清空vector

底层实现的时候,会遍历整个元素,⼀个⼀个删除,因此时间复杂度:O(N) 

// resize
void test_resize()
{vector<int> a(5, 1);a.resize(10); // 扩⼤ print(a);a.resize(3); // 缩⼩ print(a);
}// clear
void test_clear()
{vector<int> a(5, 1);print(a);a.clear();cout << a.size() << endl;print(a);
}

尾言:

欧克,全文终

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

创建并配置华为云虚拟私有云

目录 私有云 创建虚拟私有云 私有云 私有云是一种云计算模式&#xff0c;它将云服务部署在企业或组织内部的私有基础设施上&#xff0c;仅供该企业或组织内部使用&#xff0c;不对外提供服务.私有云的主要特点包括&#xff1a; 私密性&#xff1a;私有云的资源&#xff08;如…

OWASP ZAP之API 请求基础知识

ZAP API 提供对 ZAP 大部分核心功能的访问,例如主动扫描器和蜘蛛。ZAP API 在守护进程模式和桌面模式下默认启用。如果您使用 ZAP 桌面,则可以通过访问以下屏幕来配置 API: Tools -> Options -> API。 ZAP 需要 API 密钥才能通过 REST API 执行特定操作。必须在所有 …

音视频入门基础:MPEG2-PS专题(3)——MPEG2-PS格式简介

一、引言 本文对MPEG2-PS格式进行简介。 进行简介之前&#xff0c;请各位先下载MPEG2-PS的官方文档。ITU-T和ISO/IEC都分别提供MPEG2-PS的官方文档。但是ITU提供的文档是免费的&#xff0c;ISO/IEC是付费的&#xff0c;所以我们主要阅读ITU提供的官方文档&#xff0c;比如较新…

CPT203 Software Engineering 软件工程 Pt.3 系统建模(中英双语)

文章目录 5. System Modeling&#xff08;系统建模&#xff09;5.1 Context models&#xff08;上下文模型&#xff09;5.2 Interaction models&#xff08;交互模型&#xff09;5.2.1 Use case modeling&#xff08;用况建模&#xff09;5.2.2 Sequence diagram&#xff08;顺…

什么是Kafka的重平衡机制?

Kafka 的重平衛机制是指在消费者组中新增或删除消费者时&#xff0c;Kafka 集群会重新分配主题分区给各个消费者&#xff0c;以保证每个消费者消费的分区数量尽可能均衡。 重平衡机制的目的是实现消费者的负载均衡和高可用性&#xff0c;以确保每个消费者都能够按照预期的方式…

Nginx——反向代理(三/五)

目录 1.Nginx 反向代理1.1.Nginx 反向代理概述1.2.Nginx 反向代理的配置语法1.2.1.proxy_pass1.2.2.proxy_set_header1.2.3.proxy_redirect 1.3.Nginx 反向代理实战1.4.Nginx 的安全控制1.4.1.如何使用 SSL 对流量进行加密1.4.2.Nginx 添加 SSL 的支持1.4.3.Nginx 的 SSL 相关指…

VBA(Visual Basic for Applications)编程|excel|一系列网址或文件路径快速转换为可点击的超链接

很多时候&#xff0c;我们需要把导入的数据某一列转换成超链接&#xff0c;比如URL形式的列。 那么&#xff0c;大批量的情况下&#xff0c;无疑一个个手动点击是非常愚蠢的办法&#xff0c;这个时候我们就需要VBA编程来编写宏&#xff0c;通过编写宏来简化这些手动操作并不现…

【C++】图像模糊处理题目详解与实现

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述题目内容输入格式输出格式示例输入&#xff1a;输出&#xff1a; &#x1f4af;题目分析问题拆解 &#x1f4af;我的做法代码实现代码分析 &#x1f4af;老师的做法…

在 Ubuntu 22.04 上部署 AppArmor 应用安全教程

在这篇教程中&#xff0c;我们将为你设置 AppArmor 以增强应用程序的安全性。 AppArmor 是一个 Linux 安全模块&#xff0c;允许你限制各个程序的功能。通过强制执行强制访问控制策略&#xff0c;AppArmor 增强了你的应用程序和系统的安全性。 AppArmor 是一个易于使用的 Lin…

Nginx:动静分离

什么是动静分离? 动静分离 是指将网站中的静态资源(如图片、样式表、脚本等)和动态内容(如 PHP、Python、Node.js 等后端生成的内容)分开部署和处理。这样做的好处是可以利用不同的服务器或缓存策略来优化不同类型的资源。 动静分离的好处 提高性能:静态资源可以直接从…

每天40分玩转Django:Django插件开发

Django插件开发 一、插件开发概述表 阶段主要任务技术要点难度准备工作项目结构设计、环境配置项目布局、setup.py★★★☆☆开发实现功能开发、测试编写Django AppConfig、Signals★★★★☆文档编写API文档、使用说明Markdown、reStructuredText★★★☆☆发布部署PyPI打包…

什么是TDD测试驱动开发(Test Driven Development)?

什么是测试驱动开发&#xff1f; 软件开发团队通常会编写自动化测试套件来防止回归。这些测试通常是在编写应用程序功能代码之后编写的。我们将采用另一种方法&#xff1a;在实现应用程序代码之前编写测试。这称为测试驱动开发 (TDD)。 为什么要应用 TDD&#xff1f;通过在实…

后台管理系统用户退出登录方案实现

退出登录一直是一个通用的前端实现方案&#xff0c;对于退出登录而言&#xff0c;它的触发时机一般有两种&#xff1a; 1. 用户主动退出&#xff0c;即用户点击登录按钮之后退出&#xff1b; 2. 用户被动退出&#xff0c;Token过期或被 其他人"顶下来" 时退出&…

文献分享:BGE-M3——打通三种方式的嵌入模型

文章目录 1. \textbf{1. } 1. 背景与导论 1.1. \textbf{1.1. } 1.1. 研究背景 1.2. \textbf{1.2. } 1.2. 本文的研究 1.3. \textbf{1.3. } 1.3. 有关工作 2. M3-Embedding \textbf{2. M3-Embedding} 2. M3-Embedding 2.1. \textbf{2.1. } 2.1. 模型核心: 混合检索方式 2.1.1. \…

Hadoop•FinalShell连接VMware免密登录

听说这是目录哦 FinalShell连接VMware&#x1f324;️解决重连失效FinalShell的使用 免密登录⛈️能量站&#x1f61a; FinalShell连接VMware&#x1f324;️ 保持虚拟机的开机状态&#xff0c;打开FinalShell&#xff0c;如果虚拟机关机或者挂起&#xff0c;连接就会断开。 …

一个在ios当中采用ObjectC和opencv来显示图片的实例

前言 在ios中采用ObjectC编程利用opencv来显示一张图片&#xff0c;并简单绘图。听上去似乎不难&#xff0c;但是实际操作下来&#xff0c;却不是非常的容易的。本文较为详细的描述了这个过程&#xff0c;供后续参考。 一、创建ios工程 1.1、选择ios工程类型 1.2、选择接口模…

《Rust权威指南》学习笔记(五)

高级特性 1.在Rust中&#xff0c;unsafe是一种允许绕过Rust的安全性保证的机制&#xff0c;用于执行一些Rust默认情况下不允许的操作。unsafe存在的原因是&#xff1a;unsafe 允许执行某些可能被 Rust 的安全性检查阻止的操作&#xff0c;从而可以进行性能优化&#xff0c;如手…

【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 3:算法实现

目录 1 三种多头编码&#xff08;MHE&#xff09;实现1.1 多头乘积&#xff08;MHP&#xff09;1.2 多头级联&#xff08;MHC&#xff09;1.3 多头采样&#xff08;MHS&#xff09;1.4 标签分解策略 论文&#xff1a;Multi-Head Encoding for Extreme Label Classification 作者…

docker中使用Dockerfile设置Volume挂载点

关于在docker中如何使用Volume&#xff0c;可以参考文章&#xff1a; docker中使用Volume完成数据共享-CSDN博客 如果想在生成docker镜像的时候设置好挂载点&#xff0c;而不是在运行镜像生成容器时生成。 下面以自建一个tomcat镜像为例&#xff0c;演示如何在生成镜像时设置…

springboot548二手物品交易boot代码(论文+源码)_kaic

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统二手物品交易信息管理难度大&#xff0c;容错率低&#x…