sort函数对结构体|pair对组|vector容器|map排序|二维数组的第x列 的排序
目录
sort对 vector容器
sort对 vector<pair<int,int>>对组
sort对 结构体
结构体外部规定排序
结构体内部运算符重载
map容器的排序
map的键排序
map的值排序
sort对二维数组的排序
sort对 vector容器
sort()
函数可以用于对vector
容器进行排序。具体来说,sort()
函数可以接受一个表示容器的迭代器范围作为参数,然后对该范围内的元素进行排序。在排序时,我们需要传入一个比较函数,用于告诉sort()
函数如何比较元素。 下面是一个示例代码,演示如何使用sort()
函数对vector
容器进行排序:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main() {vector<int> nums = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};sort(nums.begin(), nums.end()); // 默认升序排序for(auto num : nums) {cout << num << " ";}cout << endl;sort(nums.begin(), nums.end(), greater<int>()); // 降序排序for(auto num : nums) {cout << num << " ";}cout << endl;return 0;
}
输出结果为:
1 1 2 3 3 4 5 5 5 6 9
9 6 5 5 5 4 3 3 2 1 1
在上面的代码中,我们创建了一个名为nums
的vector
容器,并初始化了一些整数值。然后,我们先调用了一次sort()
函数,对容器中的元素进行升序排序,并使用一个循环打印出排序后的结果。接着,我们又调用了一次sort()
函数,并传入了一个比较函数greater<int>()
,用于告诉sort()
函数按照降序排序。最后,我们再次使用一个循环打印出排序后的结果。 需要注意的是,sort()
函数会修改容器中的元素顺序,因此在排序前最好将容器备份一下,以免意外修改到原有数据。
sort对 vector<pair<int, int>>排序
要对vector<pair<int,int>>
的第二个元素进行排序,可以使用sort()
函数来实现。使用sort()
函数需要传入三个参数,第一个参数是要排序的起始位置,第二个参数是要排序的结束位置,第三个参数是一个函数指针,用于指定排序的规则。 下面是一个示例代码,演示如何对vector<pair<int,int>>
的第二个元素进行升序排序:
//对第二元素排序
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
bool cmp(const pair<int, int>& a, const pair<int, int>& b) {return a.second < b.second;
}
int main() {vector<pair<int, int>> v = {{1, 4}, {2, 2}, {3, 5}, {4, 1}, {5, 3}};sort(v.begin(), v.end(), cmp);for(auto p : v) {cout << p.first << " " << p.second << endl;}return 0;
}
输出结果:
4 1
2 2
5 3
1 4
3 5
在上面的代码中,我们定义了一个比较函数cmp()
,用于指定排序规则。这个函数接受两个参数,都是pair<int,int>
类型的引用。它会比较这两个pair
的第二个元素,如果第一个pair
的第二个元素小于第二个pair
的第二个元素,就返回true
,否则返回false
。 然后,在main()
函数中,我们创建了一个vector<pair<int,int>>
类型的变量v
,并初始化了一些值。然后,我们调用sort()
函数对v
进行排序。最后,我们使用一个循环打印出排序后的结果。
值得注意的是,如果是对第一个元素进行排序,则不需要cmp函数,因为sort默认对第一个元素排序
//对第一元素排序
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
//bool cmp(const pair<int, int>& a, const pair<int, int>& b) {
// return a.second < b.second;
//}
int main() {vector<pair<int, int>> v = { {1, 4}, {2, 2}, {3, 5}, {4, 1}, {5, 3} };sort(v.begin(), v.end());for (auto p : v) {cout << p.first << " " << p.second << endl;}return 0;
}
输出:
1 4
2 2
3 5
4 1
5 3
sort对 结构体
结构体外部规定排序
对结构体排序和对vector
的排序类似,也是使用sort()
函数来实现。不同之处在于,需要指定一个比较函数来告诉sort()
函数如何比较结构体对象。 下面是一个示例代码,演示如何对一个包含多个字段的结构体进行排序:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
struct Person {string name;int age;double salary;
};
bool cmpAge(const Person& p1, const Person& p2) {return p1.age < p2.age; // 按照年龄升序排序
}
bool cmpSalary(const Person& p1, const Person& p2) {return p1.salary > p2.salary; // 按照工资降序排序
}
int main() {vector<Person> people = {{"Alice", 25, 4000.0},{"Bob", 30, 5000.0},{"Charlie", 20, 3000.0},{"David", 35, 6000.0},};sort(people.begin(), people.end(), cmpAge);cout << "按照年龄升序排序:" << endl;for(auto p : people) {cout << p.name << " " << p.age << " " << p.salary << endl;}sort(people.begin(), people.end(), cmpSalary);cout << "按照工资降序排序:" << endl;for(auto p : people) {cout << p.name << " " << p.age << " " << p.salary << endl;}return 0;
}
输出结果为:
按照年龄升序排序:
Charlie 20 3000
Alice 25 4000
Bob 30 5000
David 35 6000
按照工资降序排序:
David 35 6000
Bob 30 5000
Alice 25 4000
Charlie 20 3000
在上面的代码中,我们定义了一个名为Person
的结构体,其中包含了姓名、年龄和工资三个字段。然后,我们又定义了两个比较函数cmpAge()
和cmpSalary()
,分别用于按照年龄升序和按照工资降序排序。 在main()
函数中,我们创建了一个包含四个Person
对象的vector
,并初始化了一些值。然后,我们分别调用了两次sort()
函数,分别按照年龄升序和按照工资降序排序。最后,我们使用两个循环分别打印出排序后的结果。
结构体内部运算符重载
在结构体内重载运算符,可以使我们更方便地对结构体进行排序。在C++中,可以通过重载小于号运算符<
来实现结构体的排序。具体来说,如果我们想要按照某个字段升序排序,只需要在结构体中定义一个小于号运算符的重载函数,然后在排序时传入该函数即可。 下面是一个示例代码,演示如何在结构体内重载小于号运算符,并用sort()
函数对该结构体进行排序:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
struct Person {string name;int age;double salary;bool operator < (const Person& other) const {return age < other.age; // 按照年龄升序排序}
};
int main() {vector<Person> people = {{"Alice", 25, 4000.0},{"Bob", 30, 5000.0},{"Charlie", 20, 3000.0},{"David", 35, 6000.0},};sort(people.begin(), people.end());for(auto p : people) {cout << p.name << " " << p.age << " " << p.salary << endl;}return 0;
}
输出结果为:
Charlie 20 3000
Alice 25 4000
Bob 30 5000
David 35 6000
在上面的代码中,我们在Person
结构体中重载了小于号运算符<
,使其按照年龄升序排序。在main()
函数中,我们创建了一个包含四个Person
对象的vector
,并初始化了一些值。然后,我们调用了一次sort()
函数,传入了一个空的比较函数,因为我们已经在Person
结构体内重载了小于号运算符。最后,我们使用一个循环打印出排序后的结果。 需要注意的是,重载小于号运算符时,需要将运算符重载函数声明为const
成员函数,这是因为排序函数需要保证比较操作不会修改结构体的内容。
map容器的排序
map的键排序
map
容器本身是有序的,因此不需要使用sort()
函数对其进行排序。map
容器是一种关联容器,其中的元素是按照键值有序排列的,因此我们可以说map
容器本身就已经是排序好的了。 如果我们需要对map
容器进行遍历,可以使用迭代器来访问其中的元素。map
容器的迭代器按照键值升序排列,因此我们可以直接使用一个循环来遍历map
容器中的所有元素。 下面是一个示例代码,演示如何使用迭代器遍历map
容器:
#include <iostream>
#include <map>
using namespace std;
int main() {map<string, int> scores = {{"Alice", 80},{"Bob", 70},{"Charlie", 90},{"David", 85},};for(auto it = scores.begin(); it != scores.end(); ++it) {cout << it->first << ": " << it->second << endl;}return 0;
}
输出结果为:
Alice: 80
Bob: 70
Charlie: 90
David: 85
在上面的代码中,我们创建了一个名为scores
的map
容器,并初始化了一些键值对。然后,我们使用一个迭代器it
遍历map
容器中的所有元素,并打印出每个键值对的键和值。 需要注意的是,map
容器的键和值是一一对应的,因此在遍历map
容器时,需要使用迭代器的first
和second
成员来访问键和值。在上面的代码中,it->first
代表当前迭代器指向的键,it->second
代表当前迭代器指向的值。
map的值排序
map
容器中的元素是按照键值有序排列的,因此无法直接使用sort()
函数对其值进行排序。但是,我们可以将map
容器中的键值对复制到一个vector
容器中,然后对vector
容器中的元素进行排序,最后再将排序后的结果更新到map
容器中。 下面是一个示例代码,演示如何使用vector
容器对map
容器中的值进行排序:
#include <iostream>
#include <map>
#include <vector>
#include <algorithm>
using namespace std;
int main() {map<string, int> scores = {{"Alice", 80},{"Bob", 70},{"Charlie", 90},{"David", 85},};vector<pair<string, int>> vec;for(auto it = scores.begin(); it != scores.end(); ++it) {vec.push_back(*it);}sort(vec.begin(), vec.end(), [](pair<string, int>& a, pair<string, int>& b){return a.second > b.second; // 按值降序排列});scores.clear();for(auto& p : vec) {scores.insert(p);}for(auto it = scores.begin(); it != scores.end(); ++it) {cout << it->first << ": " << it->second << endl;}return 0;
}
输出结果为:
Charlie: 90
David: 85
Alice: 80
Bob: 70
在上面的代码中,我们首先创建了一个名为scores
的map
容器,并初始化了一些键值对。然后,我们创建了一个vector
容器vec
,并使用循环将scores
中的键值对复制到vec
中。接着,我们调用了sort()
函数并传入一个比较函数,用于按照值降序排列vec
中的元素。由于vec
中的元素是键值对,因此我们需要在比较函数中指定按照second
成员排序。最后,我们清空了scores
容器,再使用循环将排序后的键值对插入到scores
容器中,并使用迭代器遍历scores
容器,打印出每个键值对的键和值。 需要注意的是,在将排序后的键值对插入到map
容器中时,我们使用了insert()
函数,而不是直接使用=
赋值运算符。这是因为map
容器中的元素是按照键值有序排列的,因此如果我们直接使用=
赋值运算符,可能会破坏原有的顺序关系。而使用insert()
函数可以保证插入的新元素仍然按照键值有序排列。
sort对二维数组的排序
二维数组可以看作是一个包含若干个一维数组的数组,因此可以使用sort()
函数对其进行排序。但是,需要注意的是,在使用sort()
函数对二维数组排序时,需要自定义比较函数,以指定按照哪个元素进行排序。 下面是一个示例代码,演示如何使用sort()
函数对二维数组进行排序:
#include <iostream>
#include <algorithm>
using namespace std;
int main() {int a[][3] = {{3, 1, 4},{2, 8, 5},{9, 7, 6},};int n = sizeof(a) / sizeof(a[0]); // 行数int m = sizeof(a[0]) / sizeof(int); // 列数sort(a, a + n, [](int* x, int* y){return x[1] < y[1]; // 按第二列升序排列});for(int i = 0; i < n; ++i) {for(int j = 0; j < m; ++j) {cout << a[i][j] << ' ';}cout << endl;}return 0;
}
输出结果为:
3 1 4
9 7 6
2 8 5
在上面的代码中,我们定义了一个名为a
的二维数组,其中包含了三个一维数组,每个一维数组有三个元素。然后,我们使用sizeof()
运算符计算出了行数和列数,并调用了sort()
函数,并传入一个比较函数,用于按照第二列升序排列二维数组中的元素。由于sort()
函数对于二维数组的排序需要在比较函数中指定按照哪个元素排序,因此我们在比较函数中指定了按照第二列排序。最后,我们使用两个嵌套循环遍历二维数组,并打印出每个元素的值。 需要注意的是,在比较函数中,我们使用了指针来表示二维数组中的一维数组。这是因为二维数组在传递给函数时,会自动转换为指向其第一行的指针,因此在比较函数中可以直接使用指针来表示一维数组。
相关文章:
sort函数对结构体|pair对组|vector容器|map排序|二维数组的第x列 的排序
目录 sort对 vector容器 sort对 vector<pair<int,int>>对组 sort对 结构体 结构体外部规定排序 结构体内部运算符重载 map容器的排序 map的键排序 map的值排序 sort对二维数组的排序 sort对 vector容器 sort()函数可以用于对vector容器进行排序。具体来…...
Java定时器Timer的使用
一、Timer常用方法 Timer应用场景: 1、每隔一段时间执行指定的代码逻辑(即按周期执行任务) 2、指定时间执行指定的代码逻辑 为方便测试并查看运行效果,首先先建一个类并继承TimerTask,代码如下: package timerTest…...
MySQL安装和配置
下载官网下载mysql解压版本:配置环境变量下载完成后直接解压到需要放的文件夹,根据文件夹来配置环境变量;新建系统变量,变量名自取,值是MySQL的目录编辑path环境变量,加上MySQL的bin目录 %MYSQL_HOME%\bin配…...
openpnnp - 载入板子后,要确定板子的放置角度
文章目录openpnnp - 载入板子后,要确定板子的放置角度概述用openpnp提供的功能来确定被夹住的板子的左下角原点位置和板子的角度备注ENDopenpnnp - 载入板子后,要确定板子的放置角度 概述 设备是有夹具的, 用百分表打过, 夹具本身在Z方向的平行度是没问题的. 但是, PCB板子的…...
HCIP知识点(前三天)
复习HCIA: 一、TCP/IP模型,OSI模型 OSI 开放式系统互联参考模型 应用层 抽象语言—>编码 表示层 编码—>二进制 会话层 应用程序内部的区分地址(无标准格式) 传输层 TCP/UDP – 分段(受MTU限制)、端…...
模板学堂丨妙用Tab组件制作多屏仪表板并实现自动轮播
DataEase开源数据可视化分析平台于2022年6月正式发布模板市场(https://dataease.io/templates/)。模板市场旨在为DataEase用户提供专业、美观、拿来即用的仪表板模板,方便用户根据自身的业务需求和使用场景选择对应的仪表板模板,并…...
C++:初识函数模板和类模板
目录 一. 泛型编程 二. 函数模板 2.1 什么是函数模板 2.2 函数模板的实例化 2.2.1 函数模板的隐式实例化 2.2.1 函数模板的显示实例化 2.3 函数模板实例化的原理 2.4 模板函数调用实例化原则 三. 类模板 3.1 什么是类模板 3.2 类模板的实例化 一. 泛型编程 泛型编程…...
3.8妇女节如何做好TikTok网红营销?
3月8日是国际妇女节,这一节日已经成为全球关注女性权益和平等的标志性日子,TikTok上话题#internationalwomensday累计播放超10亿次,话题#WomensDay2023累计播放量也将近300万次。 这个特别的日子为品牌提供了一个很好的营销机会。据Nox聚星了…...
使用Advanced Installer打包程序及运行环境
Advanced Installer 工具版本:20.1.1 设置产品信息 选中右侧【Product Details】输入产品信息 设置文件和文件夹 添加使用VS发布之后的程序文件夹 设置文件夹刷新 选中文件夹,右键选择属性,选中Synchronize标签。启用“Synchronize conten…...
华为OD机试真题Python实现【计算堆栈中的剩余数字】真题+解题思路+代码(20222023)
计算堆栈中的剩余数字 题目 向一个空栈中依次存入正整数 假设入栈元素N(1<=N<=2^31-1) 按顺序依次为Nx … N4、N3、N2、N1, 当元素入栈时,如果N1=N2+...Ny(y的范围[2,x],1 <= x <= 1000) 则 N1 到 Ny 全部元素出栈,重新入栈新元素M(M=2*N1) 如依次向栈存储6、1、…...
企业文件数据泄露防护(DLP)
什么是数据丢失防护 数据丢失防护 (DLP) 是保护数据不落入坏人之手的做法。如今,数据传输的主要问题是使大量数据容易受到未经授权的传输。通过设置足够的安全边界,您可以控制数据在网络中的移动。由于您的数据非常有价值&#x…...
不考虑分配与合并情况下,GO实现GCMarkSweep(标记清楚算法)
观前提醒 熟悉涉及到GC的最基本概念到底什么意思(《垃圾回收的算法与实现》)我用go实现(因为其他的都忘了,(╬◣д◢)ムキー!!) 源码地址(你的点赞,是我开源的…...
利用HGT聚类单细胞多组学数据并推理生物网络
单细胞多组学数据允许同时对多种组学数据进行定量分析,以捕捉复杂的分子机制和细胞异质性。然而现有的工具不能有效地推断不同细胞类型的活性生物网络以及这些网络对外部刺激的反应。 来自:Single-cell biological network inference using a heterogen…...
杂记——18.VSCode的下载及使用
这篇文章,我们来讲一下VSCode,讲一下如何下载及使用VSCode 目录 1.VSCode的下载 1.1VSCode的简介 1.2VSCode的下载与安装 1.2.1下载 1.2.2安装 2.VSCode的使用 2.1界面 2.2基础设置 2.3禁用自动更新 2.3自动保存设置 2.4Vscode更换主题 2.5…...
【独家】华为OD机试 - 最少停车数(C 语言解题)
最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧文章目录 最近更新的博客使用说明本期…...
顶级动漫IP加持之下,3A策略游戏Mechaverse如何改变GameFi
2021年是元宇宙发展的元年,元宇宙与GameFi创造了一波又一波市场热点。在经历第一波热潮之后,元宇宙的到来让不少人看到了加密市场的潜力,同时大家也意识到这将是未来的重要方向。如何将元宇宙推向更广阔的市场,让更多人能够轻松进…...
一款丧心病狂的API测试工具:Apifox!
你好,我是测试开发工程师——凡哥。欢迎和我交流测试领域相关问题(测试入门、技术、python交流都可以) 我们平时在做接口测试的时候,对于一些常用的接口测试工具的使用应该都非常熟悉了: 接口文档:Swagge…...
【前端学习】D2-2:CSS基础
文章目录前言系列文章目录1 Emmet语法1.1 快速生成HTML语法结构1.2 快速生成CSS样式语法1.3 快速格式化代码2 CSS复合选择器2.1 什么是复合选择器2.2 后代选择器(*)2.3 子选择器2.4 并集选择器(*)2.5 伪类选择器2.6 链接伪类选择器…...
Flink / Scala 实战 - 19.ProcessFunction 删除 key 的上一个定时器 TimeTimer
一.引言 ProcessFunction 原始执行状态为每个 key 注册一个较长时间 TimeTimer 并在这期间将所有对应 key 的数据都收集起来,到期完成触发。现在接到新的需求,要求判断数据类型,当特殊标识的数据到达后,需要将 TimeTimer 到期的时间提前。因此需要删掉当前 key 之前注册的老…...
MSTP基础
MSTP基础引入背景技术概览PVSTP(过渡)MSTP单生成树的缺陷1:部分VLAN不通单生成树的缺陷2:无法实现流量的负载分担多生成树解决单生成树实例引入背景 RSTP在STP基础上进行了改进,实现了网络拓扑快速收敛。但由于局域网…...
当ChatGPT遇见stable-diffusion,你不敢相信的创意艺术之旅!
前言 欢迎来到一场创意的旅程,这里将聚焦于 ChatGPT 和 stable-diffusion 这两个令人激动的技术。在这篇文章中,我们将会探索这两种技术如何结合使用,为艺术创作带来全新的可能性。我们将探讨如何利用 ChatGPT 生成富有想象力的创意…...
一文搞定!postman接口自动化测试【附项目实战详解】
目录:导读 | 接口结果判断 功能区 脚本相关 代码模板 | 集合(批量)测试 变化的参数数据 定期任务 接口执行顺序 数据传递 | 解决依赖问题 假设场景 Postman 中的操作 运行 写在最后 附带项目实战教程地址:postman接口自动化测试使用教程项…...
ctfshow【菜狗杯】wp
文章目录webweb签到web2 c0me_t0_s1gn我的眼里只有$抽老婆一言既出驷马难追TapTapTapWebshell化零为整无一幸免无一幸免_FIXED传说之下(雾)算力超群算力升级easyPytHon_P遍地飘零茶歇区小舔田?LSB探姬Is_Not_Obfuscateweb web签到 <?ph…...
旋转数组的几种做法
千淘万浪虽辛苦,吹尽黄沙始到金。 ——刘禹锡 第一种方法:遍历整个数组 题目描述: 一个数组A中存有N (N>0) 个整数,允许使用另外数组,将每个整数循环向右移动M(M>0)个位置。如果需要…...
创建虚拟机、添加镜像以及配置虚拟机
一、创建虚拟机 1、点击 “创建新的虚拟机” 2.选择“自定义配置” 到后面可以选择硬件的类型 3.默认值就行 4.选择 “稍后安装操作系统” 5.操作系统选择 “Linux”,版本结合镜像自行选择 6. 虚拟机的名称自行定义, 就是上述显示出来的名称。 虚拟机…...
Godot Engine 4.0横空出世,Vulkan大怪兽加持,画质提升简直亮瞎眼
【CSDN 编者按】经历了漫长的等待,万众瞩目的 Godot Engine 4.0 正式版在其 3.0 版本发布 5 年以后,终于带着海量令人兴奋的新功能横空出世! 整理 | 开发游戏的老王 责编 | 王子彧 出品 | CSDN(ID:CSDNnews)…...
CorelDRAWX4的VBA插件开发(四十五)建立类(2)汇总相似功能简化重复代码:一键建立设计外框加出血线和等分折页线
在上一节中已经建立好了类,那么这一节我们来调用它,先建立一个面板 然后修改框体名称 然后从左侧新建一些按钮并且以拼音为结尾进行命名 Private Sub CheckBox2_zheYe_Click() 鼠标按下几折页单选时触发If Me.CheckBox2_zheYe ThenMe.TextBox3_zheYeShu.Enabled True 让右…...
我的十年编程路 2017年篇
2016和2017,这两年是我飞速发展的两年。一方面是技术、工作能力,另一方面是对人生的思考。 随着技术能力的不断提升,博客也随之更新。在2017年伊始,我收到了CSDN学院的讲师邀请函。没错,那个时候我就有机会做视频课了…...
hadoop有多个输入路径怎么处理
在Hadoop中,可以使用FileInputFormat的addInputPath方法来添加多个输入路径。以下是实现步骤:创建一个Job对象,并设置相关的参数和配置信息。调用FileInputFormat的addInputPath方法添加输入路径。例如:FileInputFormat.addInputP…...
day6 ServletContext
ServletContext 一个Servlet对象对应一个ServletConfig。100个Servlet对象则对应100个ServletConfig对象。 只要在同一个webapp当中,只要在同一个应用当中,所有的Servlet对象都是共享同一个ServletContext对象的。 ServletContext对象在服务器启动阶段…...
wordpress可视化菜单/黄页推广
一、选择题(本题为单项选择题,每题1分,多选,不选或错选均不得分,):(25分)1、世界上第一台电子数字计算机是(B)年出现的。A、1958B、1946C、1965D、19472、微型计算机的发展史可以看作是(A )的发展历史。A、微处理器B、…...
价格列表 wordpress/在百度上怎么发布信息
一般只有父pom文件中才有dependencyManagement. dependencies:子POM会完全继承父POM中声明的dependencies,如果子POM中没有声明某个依赖项,但是父POM中声明了该依赖项,就会直接从父POM中继承该依赖项,如果子POM也声明…...
做网站现在赚钱吗/做企业网站哪个平台好
这个是开了multidex的,如果你没开multidex, 可能不是这个错误,但是也是一个dex error的错误,出现这个错误的根本原因一般是项目中出现了重复的java类导致冲突。 所谓的“项目中出现了重复的java类”一般包括下面几种情况: libs下…...
上饶市建设局培训网站/恶意点击软件哪个好
我是做前端的,接触html也就一年,一年的时间,其实也就是个小白,恰好巧了,我这个小白,一年的时间,半年时间用来接触html、css、html5、css3等,当然也包括js与jquery的学习,…...
十堰做网站的有哪些/个人网站制作
1:java项目代码上线架构图ip地址及主机名规划10.0.0.11 deploy10.0.0.12 tomcat-web0110.0.0.13 git.oldboyedu.com资料包下载地址:链接:https://pan.baidu.com/s/1YIgnUOkWLtp-LoQpIt-qVg 提取码:mpjb2:部署gitlab服务器并上传代…...