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)的更多相关文章

  1. STL顺序容器的基本操作

    容器主要分为:顺序容器和关联容器 顺序容器和关联容器,顺序容器主要有:vector.list.deque等.其中vector表示一段连续的内存地址,基于数组的实现,list表示非连续的内存,基于链表实 ...

  2. STL顺序容器【vector】【deque】【list】

    我们都知道,stl在集装箱船分为两类,订购集装箱和相关的容器. 顺序容器有三种即动态数组vector,双端队列deque,以及链表list (对csdn的文字排版严重吐槽.写好的版发表了就变了) 一: ...

  3. C++ 顺序容器 vector list deque 之比较

    在C++标准库中定义了三种顺序容器类型:vector,list和deque.所谓顺序容器就是根据位置来存储和访问元素,元素的排列次序与元素的值无关,而是由元素添加到容器的次序决定的. vector的底 ...

  4. C++ STL 顺序容器--list + 关联容器

    list 双向链表,可以双向遍历,既指向前驱节点,又指向后继但不能随机访问任意元素,可动态增加或者减少元素,内存管理自动完成,增加任何元素都不会使迭代器失效, 删除元素时,除了指向当前被删元素的迭代器 ...

  5. 第十篇:顺序容器vector,deque,list的选用规则

    前言 常见的顺序容器主要有三种 - vector,deque,list.它们实现的功能相差不大,那么实际开发中该如何进行选择呢?本文将为你解答这个问题. 分析 由于这三种容器实现的数据结构原型不同(v ...

  6. 顺序容器vector,deque,list的选用规则

    前言 常见的顺序容器主要有三种 - vector,deque,list.它们实现的功能相差不大,那么实际开发中该如何进行选择呢?本文将为你解答这个问题. 分析 由于这三种容器实现的数据结构原型不同(v ...

  7. C++ 顺序容器(vector,list、deque,stack,queue)

    顺序容器的种类有:vector,list.deque 顺序容器适配器: stack     //先进后出   栈 queue   //先进先出   队列 priority_queue   //也优先管 ...

  8. STL顺序容器用法自我总结

    顺序容器类型:vector.deque.list.forward_list.string.array. queue(单向队列)底层也是用deque(双端队列)实现的 a.swap(b); swap(a ...

  9. 【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 ...

  10. 2.1顺序容器-vector

    vector 1) *   :使用vector必须包含vector头文件.可变长的动态数组,支持随机访问,所有STL算法都可以对vector进行操作. ** :随机根据下标访问某个元素的时间是一个常数 ...

随机推荐

  1. 阿里云ECS利用密钥对ssh登录服务器

    https://blog.csdn.net/u012865381/article/details/78521087/ 1.在服务机上操作创建要远程登录的用户和密码 [root@izwz97s23bov ...

  2. redis集群redis-cloud搭建

    Redis集群中至少应该有三个节点.要保证集群的高可用,需要每个节点有一个备份机.Redis集群至少需要6台服务器. 搭建伪分布式.可以使用一台虚拟机运行6个redis实例.需要修改redis的端口号 ...

  3. Java 基础 面向对象修饰符和自定义数据类型

    不同修饰符使用细节 常用来修饰类.方法.变量的修饰符如下: public 权限修饰符,公共访问, 类,方法,成员变量 protected 权限修饰符,受保护访问, 方法,成员变量 默认什么也不写 也是 ...

  4. pd.concat/merge/join

    pandas的拼接分为两种: 级联:pd.concat, pd.append 合并:pd.merge, pd.join 一.回顾numpy.concatenate 生成1个6*3的矩阵,一个2*3的矩 ...

  5. windows go dll 框架

    乘着还没有添加商业功能之前,先给大家把福利分享了 希望有需要的朋友能够用的上 这个框架是在用windows平台,GO做的http/https服务,调用dll现有的库接口实现特定功能的大框架 //dll ...

  6. jmeter 二次开发---实现自定义函数插件

    1.前提: 有时候,Jmeter自带的函数,可能不能满足于业务的需求,这时候,我们可以自己写一个函数插件: 2.创建maven工程 一直next,输入GroupID,ArtifactId->fi ...

  7. MyBatis基础入门《六》Like模糊查询

    MyBatis基础入门<六>Like模糊查询 描述: 未改动的文件,不再粘贴出来.项目中SQL的xml映射文件重要标签如下: mapper namespace cache 配置给定命令空间 ...

  8. Linux MySQL数据库文件同步及数据库备份

    Mysql数据库链接 mysql -uroot -p -hdatacenter.jiaofukeyan.com -P33069 1.文件同步 rsync -avz --delete root@(需要同 ...

  9. 第一章 HTML基本标签

    1.HTML:HTML:超文本标签语言(标签又称标记.元素).浏览器:“解释和执行”HTML源码的工具 (运行网页的工具APP).客户端:享受服务的计算机服务器:提供服务的计算机 2.基本框架(网页最 ...

  10. caffe的model参数解析numpy多维数组的存取

    在caffe的参数进行Python解析时,需要对模型的wight和bias的参数进行解析,为了提高结果解析的可读性,需要用numpy将解析的文件进行保存 此时用到np.savetxt方法和np.sav ...