C++:顺序容器

顺序容器

  • vector 可变大小数组,快速随机访问
  • deque 双端队列,随机访问,首尾快速插入
  • list 双向链表,快速任意插入/删除
  • forward_list 单向链表
  • array 固定大小数组 array<int,n> 声明时应加大小
  • string 类似vector

顺序容器操作

  • 类型:
    • iterator
    • const_iterator
    • size_type
    • difference_type 带符号整数,足够保存两个迭代器之间的距离
    • value_type
    • reference 元素的左值类型,即value_type&
    • const_reference 即const value_type&
  • 构造:
  • (除使用迭代器参数的拷贝外,其余拷贝都要求 元素类型相同)
    • C c1(c2) 拷贝另一个容器
    • C c1(begin, end) 拷贝迭代器之间内容(array不适用)
    • C c1{a,b,c,…} 列表初始化
    • C seq(n) 只有顺序容器支持(array除外) 包含n个元素,都进行了初始化(需有默认构造函数)。显然该构造函数应是explicit的
    • C seq(n,t) ↑初始化为了t
  • 赋值
  • !!!赋值相关操作(= assign)会使容器内部的迭代器、引用和指针失效
    • c1 = c2 替换 c1与c2类型必须相同
    • c1 = { } array不支持
    • c1.assign(…) 替换掉c中元素,assign参数中的容器类型可以与c不同相当于可以用于不同类型的 =
    • a.swap(b)
    • swap(a,b)
    • swap(c1,c2) 交换两个相同类型的迭代器的内容。(除array外)元素本身并没有被交换,只是交换了两个容器的内部数据结构。 除string外,指向容器的迭代器、引用和指针在swap后都不会失效。(swap会交换两个array的元素,指针、引用、迭代器所绑定的元素不变,但值已经被交换
  • 大小
    • c.size()
    • c.max_size() 可保存最大数目
    • c.empty() 是否为空
  • 添加与删除
    • 向vector string deque添加元素会使迭代器失效
    • c.insert(p,t) 在迭代器p指向的元素之前插入t
    • c.insert(p,n,t) 插入n个t
    • c.insert(p,begin,end) 在p之前插入begin-end之间的内容(返回指向新添加的第一个元素的迭代器,范围内为空则返回p)
    • (insert都返回一个迭代器,其指向新添加的一个元素)
    • c.push_back(t) 在末尾添加
    • c.push_front(t) 在头部添加(vector string 不支持)
    • c.emplace(p,inits) 在迭代器p指向的元素之前,使用inits构造一个元素
    • c.emplace(p,begin,end)
    • c.emplace_back(init)
    • c.emplace_front(init) (vector string 不支持)
    • c.erase 删除
    • c.clear() 清空
  • 关系运算
    • == != (所以容器都支持)
    • < <= > >= (无序关联容器不支持)
  • 获取迭代器
    • begin() cbegin()
    • end() cend() 尾元素之后位置的迭代器
    • (其返回类型如:vector::iterator)
  • 访问
    • c[n] c.at(n) 返回下标为n的元素的引用
    • (c[n]的n越界时,行为未定义; c.at[n]的n越界时,抛出out_of_range)
    • c.back() 尾元素的引用(forward_list不支持) c为空则行为未定义
    • c.front() 首元素的引用 c为空行为未定义
  • 删除
    • c.pop_back() 删除c中尾元素 c为空则未定义
    • c.pop_front()
    • c.erase§ p为迭代器,返回最后一个被删除的元素之后的迭代器
    • c.erase(b,e)
    • c.clear() 清空
  • forward_list的独特操作
    • (对一个元素的操作,需要通过其前面一个元素的迭代器进行)
    • lst.before_begin() 返回首前迭代器
    • lst.cbefore_begin()
    • lst.insert_after(p,t) 在p之后添加t
    • lst.insert_after(p,n,t)
    • lst.insert_after(p,b,e)
    • lst.insert_after(p,il) il是一个花括号列表
    • 返回指向最后一个插入的迭代器
    • lst.emplace_after(p,args) 在p后构造
    • lst.erase§ 删除p之后
    • lst.erase(b,e) 删除b之后到e之间的元素(不包e)
  • 改变大小
    • c.resize(n) 新扩充的元素默认初始化
    • c.resize(n, args) 用args初始化
    • (小于原大小将抛弃后面;可能引起vector,string,deque的迭代器,引用,指针失效)
      *string vector 的内存使用
    • (为支持快速随机访问,其元素在内存中连续。当无法获取新的内存空间时,将分配比 新的空间需求 更大的内存空间(翻倍),以备用。)
    • c.capacity() 在不扩张内存占用的情况下可以容纳多少个元素。 只适用与vector和string
    • c.reserve(n) 分配至少能容纳n个元素的内存空间
    • c.shrink_to_fit() 将capacity()减少为size()相同的大小

注意

  • 改变容器的循环:每步循环中都更新迭代器、引用、指针。
  • 不要缓存end()返回的迭代器

容器适配器 adaptor

  • priority_queue 优先队列 (可基于vector deque)
  • stack 栈 (可基于 除array forward_list外的容器)
  • queue 队列 (可基于list deqeue)

类型和操作

  • size_type
  • vaule_type
  • container_type 底层容器
  • A a()
  • A a© 拷贝c创建
  • a.empty()
  • a.size()
  • stack(**在stack头文件中):
    • s.pop()
    • s.push(item)
    • s.emplace(args)
    • s.top()
  • queue和priority_queue(在queue头文件中):
    • q.pop()
    • q.front()
    • q.back() 只适用于queue
    • q.top()
    • q.push()
    • q.emplace()

priority_queue 默认使用<运算符相对优先级关系

stack<int> s1;
stack<int, vector<int>> s2;

s1.push(1);
s1.emplace(2);
int a = s1.top();
s1.pop();
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

绫零依

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值