C++ STL--顺序容器(vector)
STL(标准模板库)
一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量、链表、队列、栈。
C++标准模板库的核心包含以下组件:
容器(containers):用来管理某一类对象的集合,C++提供了各种不同类型的容器,如deque,list,vector,map
算法(algorithms)算法用于作用容器。提供各种执行操作,包括初始化,排序,搜索,转换等
迭代器(iterators)迭代器用于遍历对象集合的元素
vector(向量)
vector的数据安排和操作方式与数组很像,两者区别在于空间运用的灵活性,数组是静态空间,一旦分配,不可改变;vector是动态空间,随着元素加入,内部机制可以动态的增加或者减少元素,内存管理可以自动完场,并且提供了2个成员函数:capacity和reserve,使程序员可以与vector容器内存分配的实现部分交互工作。
capacity获取容器需要分配更多的存储空间之前能够储存的元素总数
reserve操作告诉vector容器应该预留多少个元素的存储空间
capacity和size的区别
size指容器当前拥有的元素个数
capacity是指容器必须分配之前可以存储的元素总数,当元素个数超过capacity总数时,因空间 不足,重新分配一块大的空间,复制元素,再释放旧的空间。
vector的迭代器
迭代器在内存重新分配时失效(它所指的元素在该操作后,前后不同)。插入该元素以后,指向当前插入元素之后的任何元素迭代器都将失效。当插入元素后,元素个数超过capacity(),内存会重新分配,此时迭代器全部失效。当删除元素时,指向被删除元素之后的任何元素的迭代器都将失效。
二维数组
rowCount = array.size();
colCount = array[0].size;
vector作为函参数或者函数返回值,必须是引用
doublle distance(vector<int>&a,vector<int>&b)
常用操作:
- 头文件 #include<vector>
- 创建vector对象 vector<int>vec;
- 尾部插入元素 vec.push_back(a);
- 使用下标访问元素 vec[]
- 使用迭代器访问元素 vector<int>::iterator it;
- for(it=vec.begin();it!=vec,end();it++)
- {
- cout<<*it<<endl;
- }
- 插入元素 vec.insert(vec.begin()+i,a)在第i+1个元素前面插入a;
- 删除元素 vec.erase(vec.begin()+);删除第3个元素
- vec.erase(vec.begin()+i,vec.end()+j);删除区间[i,j-];区间从0 开始
- 向量大小 vec.size()
- 清空 vec.clear()
常用算法
- (1) 使用reverse将元素翻转:需要头文件#include<algorithm>
- reverse(vec.begin(),vec.end());将元素翻转,即逆序排列!
- (在vector中,如果一个函数中需要两个迭代器,一般后一个都不包含)
- (2)使用sort排序:需要头文件#include<algorithm>,
- sort(vec.begin(),vec.end());(默认是按升序排列,即从小到大).
- 可以通过重写排序比较函数按照降序比较,如下:
- 定义排序比较函数:
- bool Comp(const int &a,const int &b)
- {
- return a>b;
- }
- //调用时:sort(vec.begin(),vec.end(),Comp),这样就降序排序。
- //输出Vector的中的元素
- vector<float> vecClass;
- int nSize = vecClass.size();
- //打印vecClass,方法一:
- for(int i=;i<nSize;i++)
- {
- cout<<vecClass[i]<<" ";
- }
- cout<<endl;
- //需要注意的是:以方法一进行输出时,数组的下表必须保证是整数。
- //打印vecClass,方法二:
- for(int i=;i<nSize;i++)
- {
- cout<<vecClass.at(i)<<" ";
- }
- cout<<endl;
- //打印vecClass,方法三:输出某一指定的数值时不方便
- for(vector<float>::iterator it = vecClass.begin();it!=vecClass.end();it++)
- {
- cout<<*it<<" ";
- }
- cout<<endl;
- //二维数组的使用:
- #include "stdafx.h"
- #include <cv.h>
- #include <vector>
- #include <iostream>
- using namespace std;
- int main()
- {
- using namespace std;
- int out[][] = { , ,
- , ,
- , };
- vector <int*> v1;
- v1.push_back(out[]);
- v1.push_back(out[]);
- v1.push_back(out[]);
- cout << v1[][] << endl;//
- cout << v1[][] << endl;//
- cout << v1[][] << endl;//
- cout << v1[][] << endl;//
- cout << v1[][] << endl;//
- cout << v1[][] << endl;//
- return ;
- }
C++ STL--顺序容器(vector)的更多相关文章
- STL顺序容器的基本操作
容器主要分为:顺序容器和关联容器 顺序容器和关联容器,顺序容器主要有:vector.list.deque等.其中vector表示一段连续的内存地址,基于数组的实现,list表示非连续的内存,基于链表实 ...
- STL顺序容器【vector】【deque】【list】
我们都知道,stl在集装箱船分为两类,订购集装箱和相关的容器. 顺序容器有三种即动态数组vector,双端队列deque,以及链表list (对csdn的文字排版严重吐槽.写好的版发表了就变了) 一: ...
- C++ 顺序容器 vector list deque 之比较
在C++标准库中定义了三种顺序容器类型:vector,list和deque.所谓顺序容器就是根据位置来存储和访问元素,元素的排列次序与元素的值无关,而是由元素添加到容器的次序决定的. vector的底 ...
- C++ STL 顺序容器--list + 关联容器
list 双向链表,可以双向遍历,既指向前驱节点,又指向后继但不能随机访问任意元素,可动态增加或者减少元素,内存管理自动完成,增加任何元素都不会使迭代器失效, 删除元素时,除了指向当前被删元素的迭代器 ...
- 第十篇:顺序容器vector,deque,list的选用规则
前言 常见的顺序容器主要有三种 - vector,deque,list.它们实现的功能相差不大,那么实际开发中该如何进行选择呢?本文将为你解答这个问题. 分析 由于这三种容器实现的数据结构原型不同(v ...
- 顺序容器vector,deque,list的选用规则
前言 常见的顺序容器主要有三种 - vector,deque,list.它们实现的功能相差不大,那么实际开发中该如何进行选择呢?本文将为你解答这个问题. 分析 由于这三种容器实现的数据结构原型不同(v ...
- C++ 顺序容器(vector,list、deque,stack,queue)
顺序容器的种类有:vector,list.deque 顺序容器适配器: stack //先进后出 栈 queue //先进先出 队列 priority_queue //也优先管 ...
- STL顺序容器用法自我总结
顺序容器类型:vector.deque.list.forward_list.string.array. queue(单向队列)底层也是用deque(双端队列)实现的 a.swap(b); swap(a ...
- 【c++进阶:c++ 顺序容器vector,string,deque,list,forward_list,array常用性质】
常用5种顺序容器性质: https://blog.csdn.net/oil_you/article/details/82821833 关于deque https://www.cnblogs.com/L ...
- 2.1顺序容器-vector
vector 1) * :使用vector必须包含vector头文件.可变长的动态数组,支持随机访问,所有STL算法都可以对vector进行操作. ** :随机根据下标访问某个元素的时间是一个常数 ...
随机推荐
- vant - 弹框 【Popup 弹出层】【DatetimePicker 时间选择】
[HelloWorld.vue] <template> <div class="hello"> <van-row class="m-head ...
- 图片在IE8浏览器多一个有边框问题解决办法
最后在网上找了一下答案,IE8浏览器图片多一个有色边框,而Chrome浏览器没有边框的解决办法. 指定img的边框样式: img{border-style:none;}
- 以太坊如何使用CPU挖矿?
CPU挖掘 你可以用电脑的中央处理器(CPU)挖以太币.自从GPU矿工的效率高出两个数量级,它就不再盈利了.然而你可以用CPU挖掘在Morden测试网或私有链上挖矿,以便创建你测试合约和交易所需要的以 ...
- Ext.define细节分析
自己写的其实还是不懂,再看看别人写的吧Extjs4 源码分析系列一 类的创建过程https://www.cnblogs.com/creazyguagua/p/4302864.htmlhttp://ww ...
- 《全栈性能Jmeter》-6JMeter元件详解
- malloc调用后经历了什么?
进程生成虚拟地址空间,有堆地址,由于是虚拟地址,所以没有做内存碎片化处理,只是在虚拟内存不够的时候调用brk,进行堆大小的调整,然后申请到虚拟内存是页,同MMU映射到物理地址,然后并不是每个页都预先加 ...
- 前端的icon处理
http://fontawesome.io/ 发现CSS也可以生成icon
- vue中动态绑定class
我用的element-ui primary默认是这个颜色,ui设计的是这个颜色所以我们先要重写 .el-button--primary的样式 因为默认是没有勾选的所有事灰色所以下面重写样式为灰色 .e ...
- mysql group_concat用法
MySQL中group_concat函数 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔 ...
- js中var a=new Object()和var a={}有什么区别吗?
应该是没有区别的,两者都是生成一个默认的Object对象.js和其它语言一样,一切对象的基类都是Object,所以,new Object()和简易的{}是同样的空对象,就是默认的对象.本来我以为{}应 ...