C++ 基础函数的介绍及使用(Vector+deque+STL)

 更新时间:2022年06月28日 14:19:58   作者:还是要努力呀!  
这篇文章主要介绍了C++ 基础函数的介绍及使用(Vector+deque+STL),文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

一、Vector的基础函数

之前有学习过 vector、set、map等容器,都是需要什么搜什么,没有详细的了解其中的内容。最近在看 STL 的相关内容,就顺手整理一些基础性内容,避免以后遇到的时候再临时抱佛脚。

1. 构造函数

vector<T> v;     //创建一个空的vector
vector<T> v(int nSize, const t& t);     //创建一个vector,元素个数为nSize,元素值均为t
vector<T> v(int nSize);     //创建一个vector,元素个数为nSize
vector<T> v(const vector&);     //复制构造函数
vector<T> v = vector(begin,end);     //复制[begin,end]范围内另一个数组的元素到 v中

2. 增加元素

v.push_back(const T& x);     //在vector尾部增加一个元素x
v.insert(iterator it, const T& x);     //在vector中迭代器指向的元素前插入一个元素x
v.insert(iterator it, int n,const T& x);     //在vector中迭代器指向的元素前插入n个相同的元素x
v.insert(iterator it,const_iterator first,const_iterator last);     //在vector中迭代器指向的元素前插入另一个相同类型vector中[first,last]间的元素

3. 删除元素

v.erase(iterator it);     //删除vector中迭代器指向的元素
v.erase(iterator first, iterator last);     //删除vector中[first,last)的元素
v.pop_back();     //删除vector中的最后一个元素
v.clear();     //清空向量中的所有元素

4. 遍历vector

v.at(int nPos);     //返回nPos位置元素
v.front();     //返回vector的首元素
v.back();     //返回vector的尾元素
v.begin();     //返回指向第一个元素的迭代器
v.end();     //返回指向最后一个元素下一位置的迭代器
v.rbegin();     //反向迭代器,指向最后一个元素
v.rend();     //反向迭代器,指向第一个元素的前一个位置

5. 判断函数

v.empty();     //判断vector是否为空

6. 大小函数

v.size();     //返回vector中元素个数
v.capacity();     //返回当前vector中所能容纳的最大元素个数
v.max_size();     //返回当前vector最大可允许的元素数量个数

7. 其他函数

v.swap(vector& v2);     //交换两个同类型的vector
v.assign(int n,const T& t);     //设置vector中第n个元素的值为t
v.assign(const_iterator first,const_iterator last);     //vector中[first,last)中的元素设置成当前vector元素

二、deque的介绍及使用

deque(double ended queue) 作为双端队列,不论在尾部或头部插入元素,都十分便捷。而在中间插入元素会比较费时,因为必须移动中间其他的元素。

双端队列是一种随机访问的数据类型,提供了在序列两端快速插入和删除的功能,它可以在需要的时候改变自身大小,完成了标准 C++ 数据结构中队列的所有功能。

三、deque 和 vector的差别

  • deque 则是一种双向开口的连续线性空间,vector是单向开口的连续线性空间。
  • deque 对象在队列的两端插入和删除元素比较高效,vector 在序列末尾插入和删除元素比较高效。
  • deque 允许在常数时间内在序列头部进行元素的插入和删除操作,并且 deque 没有所有的 capacity() 观念,它是动态地以分段连续空间组合而成,随时可以增加一段新的空间并链接起来。vector会因旧空间不足而重新配置一块更大空间,然后复制元素,再释放旧空间,即空间预留机制。

虽然 deque 也提供 Random Access Iterator,但它的迭代器并不是普通的指针,复杂度较高。因此除非必要,应尽可能选择使用 vector 而非 deque。对 deque 的排序操作,可以先完整复制到一个 vector 中,使用 STL 中的排序操作对 vector 排序后,再复制回 deque。

deque 通常由一些独立的区块组成,第一个区块朝某方向扩展,最后一个区块朝另一方向扩展。它允许较为快速地随机访问,但不像 vector 一样把所有对象保存在一个连续的内存块,而是多个连续的内存块,并且在一个映射结构中保存对这些块以及顺序的跟踪。

1、构造函数

#include<deque>
deque<type> deq;            //声明一个元素类型为 type 的双端队列 deq
deque<type> deq(nSize);            //声明含有 nSize 个默认初始化元素的 deq
deque<type> deq(nSize, value)            //声明含有 nSize 个值为 value 的元素的deq
deque<type> deq(MyDeque);            //复制MyDeque到deq
deque<type> deq(first, last);            //使用迭代器first,last范围内的元素初始化deq

2、常用成员函数

deq[nPos];            //访问双向序列中 nPos 位置上的元素
deq.front();            //返回第一个元素
deq.back();            //返回最后一个元素
deq.push_front(x);            //把元素 x 插入到 deq 的头部
deq.pop_front();            //弹出 deq 的第一个元素
deq.push_back(x);            //把元素 x 插入到 deq 的尾部
deq.pop_back();            //弹出 deq 的最后一个元素

3、特点

  • 支持使用 [] 和 at() 进行随机访问,但性能没有 vector 好;
  • 可以在内部进行插入和删除操作,但性能没有 list 好;
  • deque 的元素存取和迭代器操作会稍微较慢,因为内部结构中多一个间接过程;
  • deque 的迭代器是一种特殊的智能指针,能够在不同区块之间跳转;
  • deque 不支持对容量和内存分配时机的控制。
  • deque 的内存重分配优于 vector,因为其内部不需要复制所有元素。
  • deque 的内存块不再被使用时,会被释放。但是该机制由实际操作版本控制是否执行。

四、STL中容器的通用操作函数

最近在学习 C++ 中 STL 标准库中的东西,关于list、vector、deque、set、map等容器的操作函数中存在一些通用函数,整理出来一起学习。

1. 构造函数

ContType<T> C;            //创建一个空容器
ContType<T> C(nSIze);        //创建一个含有 nSize 个默认元素的容器
ContType<T> C(nSize, Value);    //创建一个含有 nSize 个值为 Value 的元素的容器
ContType<T> C1(C2);  //复制一个同类型容器
ContType<T> C(first, last);      //复制[first,last)范围内的元素到新容器中
C.~ContType();            //删除所有元素,释放内存

2. 判断函数

C.empty();            //判断容器是否为空
C1==C2;            //判断c1是否等于c2

3. 访问函数

lst.get_allocator();        //返回容器的内存模型
C.begin();        //正向迭代器,指向第一个元素
C.end();         //正向迭代器,指向最后一个元素的下一位置
C.rbegin();     //反向迭代器,指向最后一个元素
C.rend();      //反向迭代器,指向第一个元素的前一个位置
C.size();      //返回容器当前存储的元素数量
C.max_size();  //返回容器能容纳的最大元素数量

4. 赋值函数

C1=C2;//将c2的值赋给c1

//swap()交换函数
C1.swap(C2);//交换c1和c2的数据
Swap(C1,C2);//同上

//assign()赋值函数
C.assign(size_type nSize, const_type Value);        //将list中元素替换为 nSize 个值为 Value 的元素
C.assign(iterator first,iterator last);        //将[first,last)中的元素复制到当前容器中
C.assign(ContType<T> &C2);           //将另一个容器中的元素复制到当前容器中

5. 操作函数

C.clear();//清空容器

//insert()插入元素
C.insert(iterator iter, const_type Value);//在 iter 指向的位置插入值为 Value的元素
C.insert(iterator iter,size_type num, const_type &Value);//在 iter 指向的位置插入 num 个值为 Value的元素
C.insert(iterator iter,iterator fisrt,last);//在 iter 指向的位置插入[first,end)区间内的所有元素

//erase()删除元素
C.erase(nPos,nSize);//删除从下标 nPos 开始的 nSize 个元素
C.erase(iterstor iter);//删除该迭代器指向的元素
C.erase(iterator first,iterator lase);//删除[first,last)区间的元素

//vector、deque、list
C.front();        //返回第一个元素
C.back();        //返回最后一个元素
C.resize();        //改变list的大小
//deque、list
C.pop_front();        //删除第一个元素
C.push_front(Value);        //在容器头部添加一个元素Value
//vector、deque、list
C.front();               //返回第一个元素
C.back();               //返回最后一个元素
C.resize();             //改变list的大小
C.pop_back();           //删除最后一个元素
C.push_back(Value);     //在容器末尾添加一个元素Value
//vector、list
C.reverse();        //把list中的元素反转

到此这篇关于C++ 基础函数的介绍及使用(Vector+deque)的文章就介绍到这了,更多相关C++ deque Vector内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • OpenCV 2.4.3 C++ 平滑处理分析

    OpenCV 2.4.3 C++ 平滑处理分析

    平滑也称模糊, 是一项简单且使用频率很高的图像处理方法,本文将详细介绍OpenCV 2.4+ C++ 平滑处理,需要了解更多的朋友可以详细参考下
    2012-11-11
  • C语言中的线程信号控制详解

    C语言中的线程信号控制详解

    这篇文章主要通过一些示例为大家详细介绍一下C语言中的线程信号控制,文中的示例代码讲解详细,对我们深入了解C语言有一定的帮助,感兴趣的可以学习一下
    2023-02-02
  • C++实现LeetCode(155.最小栈)

    C++实现LeetCode(155.最小栈)

    这篇文章主要介绍了C++实现LeetCode(155.最小栈),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C语言每日练习之字符串反转

    C语言每日练习之字符串反转

    这篇文章主要介绍了C语言字符串反转,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-11-11
  • C++ 正则表达式的应用详解

    C++ 正则表达式的应用详解

    正则表达式(regular expression)描述了一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某种子串、将匹配的子串替换或者从某个串中取出符合某个条件的子串等
    2021-11-11
  • C++中重载、重写(覆盖)和隐藏的区别实例分析

    C++中重载、重写(覆盖)和隐藏的区别实例分析

    这篇文章主要介绍了C++中重载、重写(覆盖)和隐藏的区别,是C++面向对象程序设计非常重要的概念,需要的朋友可以参考下
    2014-08-08
  • C++ DLL动态库的创建与调用(类库,隐式调用)

    C++ DLL动态库的创建与调用(类库,隐式调用)

    本文主要介绍了C++ DLL动态库的创建与调用(类库,隐式调用),文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • C语言绘制三角函数曲线

    C语言绘制三角函数曲线

    这篇文章主要为大家详细介绍了C语言绘制三角函数曲线,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-06-06
  • 数据结构之数组Array实例详解

    数据结构之数组Array实例详解

    这篇文章主要介绍了数据结构之数组Array实例详解的相关资料,需要的朋友可以参考下
    2017-05-05
  • C语言实现经典24点纸牌益智游戏

    C语言实现经典24点纸牌益智游戏

    这篇文章主要为大家详细介绍了C语言实现经典24点纸牌益智游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10

最新评论