STL顺序容器用法自我总结
顺序容器类型:vector、deque、list、forward_list、string、array。
queue(单向队列)底层也是用deque(双端队列)实现的
a.swap(b);
swap(a,b);
可以交换两个容器的数据结构
初始化:
声明时定义
.assign(n,t),以n个t初始化
.assign(b,e),用迭代器b到e初始化
.assign(il),用il表示的数据初始化
添加元素:
参数中有迭代器的,都会返回迭代器。
下面的函数参数中的p表示迭代器。
c.insert(p,args);返回插入的新元素的位置
c.emplace(p,inits);和insert函数功能一样,不过不必构建临时变量,省时间。
同理push_back()和emplace_back(),以及push_front()和emplace_front()。
还可以insert(p,n,t),向p前面插入n个t。
insert(p,b,e),其中b、e都是迭代器,表示向p前面插入b到e表示的内容。
insert(p,il),il表示如{1,2,3}这样的大括号列表,将il表示的数据插入到p前面。
删除元素:
erase ( p),删除迭代器p指代的位置,返回被删除的元素下一个位置的迭代器。
erase(b,e),删除迭代器b到e指代的位置,返回被删除的最后一个元素的下一个迭代器,其实就是e的位置,删除[b,e)半闭半开区间。
链表容器的插入删除操作有些特殊,因为链表不是连续容器。
insert_after()和erase_after()。
管理容量:
.size()
.capacity()
.reserve(n),分配至少容纳n个元素的空间
.shrink_to_fit(),减少capacity到size的大小
.resize(),减少size(注意如果新size小于之前的size,会截取掉尾部的数据!)
查找
string有自己的find系成员函数。
所有容器都可以使用的:
find(b,e,T),在b到e区间内寻找T
find_first_of(b,e,T),类似
fidn_if(b,e,F),F是布尔函数,在b到e区间寻找满足F的第一个迭代器
string的成员函数:
string.find(args)
string.rfind(),倒着找第一个(即找最后一个)
string.find_first_of(字符串q),查找在字符串中首次出现的q中的任意字符
stirng.find_last_of()
string.find_first_not_of()
string.find_last_not_of()
其中args可以是(字符+pos=0),(字符串,pos=0),(字符数组头指针,pos,n)【表示从string的pos位置开始找[头指针,头指针+n)的数据 】。
比较
string.compare(s2),返回0表示相同,1表示字典序大于s2,-1表示字典序小于s2。
STL顺序容器用法自我总结的更多相关文章
- STL顺序容器的基本操作
容器主要分为:顺序容器和关联容器 顺序容器和关联容器,顺序容器主要有:vector.list.deque等.其中vector表示一段连续的内存地址,基于数组的实现,list表示非连续的内存,基于链表实 ...
- STL顺序容器【vector】【deque】【list】
我们都知道,stl在集装箱船分为两类,订购集装箱和相关的容器. 顺序容器有三种即动态数组vector,双端队列deque,以及链表list (对csdn的文字排版严重吐槽.写好的版发表了就变了) 一: ...
- C++ STL 顺序容器--list + 关联容器
list 双向链表,可以双向遍历,既指向前驱节点,又指向后继但不能随机访问任意元素,可动态增加或者减少元素,内存管理自动完成,增加任何元素都不会使迭代器失效, 删除元素时,除了指向当前被删元素的迭代器 ...
- STL常用容器用法
-1. 本文章中所有函数原型均为C++98的标准. 通用的操作 //遍历容器--以vector,map为例 vector<int> vt; map<int,int> mp; f ...
- STL之顺序容器
顺序容器: vector:数组 list:链表 deque:双端数组 顺序容器适配器: stack:堆栈 queue:队列 priority_queue:优先级队列 deque是一个动态数组 dequ ...
- C++——STL中三种顺序容器的简要差别
C++ STL 提供了3个顺序容器 :vector, deque, list Vector动态数组.支持高速訪问:list双向链表,支持高速插入和删除. vector 中的元素是顺序存放的.所以随机訪 ...
- STL之如何选择顺序容器
一.顺序容器的分类 顺序容器:vector向量.list链表.deque双端队列: 优先级最高的是vector向量,它的速度比较快,优点最多: 在程序设计中,容器可以切换: #include < ...
- c++复习:STL之容器
1 STL的string 1 String概念 string是STL的字符串类型,通常用来表示字符串.而在使用string之前,字符串通常是用char*表示的.string与char*都可以用来表示字 ...
- C++-STL:vector用法总结
目录 简介 用法 1. 头文件 2. vector的声明及初始化 3. vector基本操作 简介 vector,是同一类型的对象的集合,这一集合可看作可变大小的数组,是顺序容器的一种.相比于数组,应 ...
随机推荐
- mysql建立索引类型及索引建立的原则
索引类型:Unique(唯一索引,一般为主键),Normal(一般索引,普通字段,可做组合索引),索引方法:BTREE 1.选择唯一性索引 唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录 ...
- python 元组 列表 字典
type()查看类型 //取整除 **幂 成员运算符: in x在y序列中,就返回true 反之 not in 身份运算符: is is not 逻辑运算符 and or not 字符编码 问题 ...
- 疫情下的传统商企自救|4个Tips搭建销量过亿直播间
新冠肺炎爆发以来,线下商企遭受巨大冲击.出于疫情防控需要,不少门店选择暂时停业:而消费者们更是响应号召.足不出户.这场疫情促使消费者的消费习惯和方式进一步转向线上订购转变,直播.短视频等领域逆势而起, ...
- idea的插件库连不上网络
如果你试遍了网上的方法都没有解决网络问题,建议换个网络,比如切换到电信网络.
- Tensorflow中one_hot() 函数用法
官网默认定义如下: one_hot(indices, depth, on_value=None, off_value=None, axis=None, dtype=None, name=None) 该 ...
- 04 部署uwsgi web服务器
1 建立uwsgi软链接 进入虚拟环境,并在虚拟环境中安装uwsgi,建立软链接. $ cd /venv/thvenv/bin $ activate $ pip install uwsgi 2 创建u ...
- actiBPM插件的办法
1.下载actiBPM到本地 从IDEA官网下载actiBPM.jar包 IDEA官网:https://plugins.jetbrains.com/ 官网搜索actiBPM 2.从本地安装actiBP ...
- 题解【洛谷P1983】[NOIP2013]车站分级
题面 题解 不难想到拓扑排序 于是每一个等级高的向等级低的连一条边 考虑拓扑排序过程中的分层 对于每个点进行分层 于是答案就是这些点中的最大层数 然后就会RE 发现我们多连了一些重复的边 用一个标记数 ...
- jQuery添加/删除元素
jQuery append() 方法 jQuery append() 方法在被选元素的结尾插入内容(仍然该元素的内部). 追加前:<p>这是一个文本段落</p> $(" ...
- Qt- 图形界面应用程序的运行模式
main() 定义主窗口 ————>fd = DefineMainWindow() 创建主窗口————>win = CreateMainWindow() 创建主窗口中的元素-----> ...