c++ 常用的STL

前言

写这篇博客目的是为了记录在刷算法题中使用过的STL,因为有些不太常用的会遗忘。这篇博客只是作为笔记,不是详细的STL,因此只会对常用方法说明,不会详细介绍。此外在后面用到新的STL内容时会再补充。

列队

基础列队

基本列队是queue,其中主要有入队、出队、读取队尾或则队首元素、获取队列长度这几个方法。

方法 说明
pop() 删除首元素
push() 添加一个元素
front() 获取队首元素
back() 获取队尾元素
size() 队列长度
empty() 判断是否为空

这里是基础列队queue,有的时候在写算法时为了满足某些需要。需要队列可以弹出队尾元素。这里queue并没有提供相应的方法,当然如果需要可以使用迭代器的 erase() 方法,该方法目的是删除某个元素,并将后面元素前移。

双端操作列队

这里可以使用修改版的列队deque,该列队提供了更加多样的操作,使得列队可以在任何端进行插入和删除操作。这里deque相比于vector优势是速度快一点。

方法 说明
pop_front() 删除队首元素
pop_back() 删除队尾元素
push_front() 队首添加一个元素
push_back() 队尾添加一个元素
front() 获取队首元素
back() 获取队尾元素
size() 队列长度
empty() 判断是否为空

向量数组

向量数组vector,向量数组相比于传统的数组,优势在于其长度可以动态扩展,而不必一开始就规定数组大小。并直接提供了队尾添加删除操作。

方法 说明
pop_back() 删除尾元素
push_back() 向尾部添加一个元素
front() 获取首元素
back() 获取尾元素
size() 队列长度
empty() 获取数组长度

例如代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	vector<int> a;
	for(int i=0;i<10;i++)
		a.push_back(i);
	a.pop_back();
	for(int i=0;i<a.size();i++){
		cout<<a[i]<<' ';
	}
	
	cout<<endl<<a.size();
}

结果是:

这里经常配合使用的方法是**unique(a,b)**该方法是将重复元素移动到数组尾部,参数分别是开始和结束部分迭代器。返回不重复部分最后一个元素的迭代器。

集合

集合特点是自动排序,并且集合没有重复元素。集合没有提供按元素查找方式,可以通过迭代器实现,具体实现看这篇博客

基础集合

基础集合是set 该集合不允许出现重复元素(出现相同元素会被覆盖)。默认按照升序排序。也可以指定排序方式。

方法 说明
size() 集合元素个数
insert() 插入元素
empty() 集合是否为空
find() 查找元素,返回迭代器
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
struct cmp{
	 bool operator()(const int&a,const int&b){
		if(a<b)
			return false;
		return true;
	}
};//定义的排序方法
int main(){
	set<int,cmp> m;		//按照定义进行排序
	set<int>::iterator iters;
	m.insert(1);
	m.insert(9);
	iters=m.begin();
	cout<<*iters<<' ';
	cout<<m.size();
}

结果是

bash 复制代码
9 2

可重复集合

可重复集合是multiset,该集合区别是可以重复存储相同元素。不会覆盖,除此之外方法等和set基本没什么区别。

映射

映射是map,映射通过键值对一一映射,从而可以快速查询数据。一般来说使用时和数组差不多。没什么很多方法,如果一个键值对不存在,并查询一个不存在的键时,如果值类型是整形,则其值等于0

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	map<int,int> m;
	m[1]=100;
	m[2]++;
	cout<<m[1]<<' '<<m[2]<<' '<<m[3]<<endl;
}

结果为:

pair

pair是将两个数据组成一个元素,其中这两个数据类型可以是不同类型。主要通过first 访问第一个数据元素,通过second访问第二个数据元素。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	pair<int,char> a;
	a.first=4;
	a.second='a';
	cout<<a.first<<' '<<a.second;
}

结果为

迭代器

迭代器类似于指针,对于上述数据类型。都可以获取其相应的迭代器。如果c++版本够高可以直接使用auto 接收返回的迭代器。不过我的c++版本太低只能自己定义。其定义方式是数据类型::iterator 迭代器名.具体如下如下:

bash 复制代码
定义一个map<int,int>名为iters的迭代器:
map<int,int>::iterator iters

在上述类型中一般使用如下获取相应迭代器

方法 说明
begin() 指向第一个元素迭代器
end() 最后的迭代器

这两个方法是通用的,有些数据类型也提供其他放回迭代器的方法,例如set的find()方法,返回一个指向目标元素的迭代器。迭代器访问是通过*迭代器变量名

迭代器向前移动可以通过方法advance(iters,steps)参数分别是迭代器名和向前移动步数。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	deque<int> a;
	deque<int>::iterator iters; //deque<int>类型迭代器
	for(int i=0;i<10;i++){
		a.push_back(i);
	}
	iters=a.begin();			//获取指向第一个元素的迭代器
	for(int i=0;i<a.size();i++){
		cout<<*iters<<' ';
		advance(iters,1);		//迭代器向前移动一个元素
	}
}

结果为

删除方法是erase()该方法将迭代器指向元素删除,并将后面元素向前移动。

例如代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	deque<int> a;
	deque<int>::iterator iters; 
	for(int i=0;i<10;i++){
		a.push_back(i);
	}
	iters=a.begin();
	a.erase(iters);
	iters=a.begin();
	cout<<*iters<<endl; 

结果为;

相关推荐
Ddddddd_15811 分钟前
C++ | Leetcode C++题解之第416题分割等和子集
c++·leetcode·题解
编程版小新40 分钟前
C++初阶:STL详解(四)——vector迭代器失效问题
开发语言·c++·迭代器·vector·迭代器失效
AlexMercer10122 小时前
【C++】二、数据类型 (同C)
c语言·开发语言·数据结构·c++·笔记·算法
小灰灰爱代码2 小时前
C++——求3个数中最大的数(分别考虑整数、双精度数、长整数的情况),用函数模板来实现。
开发语言·c++·算法
BeyondESH4 小时前
Linux线程同步—竞态条件和互斥锁(C语言)
linux·服务器·c++
豆浩宇4 小时前
Halcon OCR检测 免训练版
c++·人工智能·opencv·算法·计算机视觉·ocr
WG_174 小时前
C++多态
开发语言·c++·面试
Charles Ray6 小时前
C++学习笔记 —— 内存分配 new
c++·笔记·学习
重生之我在20年代敲代码6 小时前
strncpy函数的使用和模拟实现
c语言·开发语言·c++·经验分享·笔记
迷迭所归处11 小时前
C++ —— 关于vector
开发语言·c++·算法