Vector STL简要介绍

关于STL中的vector容器,以下做一些相关介绍。

vector 简要概述

  • vector 称作向量类,属于容器类,实现了动态的数组,用于元素数量变化的对象数组。简单来说,vector 也可以当作普通数组去使用,配合 vector 中的迭代器,能够更好管理其中的内容。
  • vector 类下标也从 0 开始,与普通数组不同的是,每当使用 push_back 增加内容的时候,其对象元素个数大小会增大,当使用 erase 释放元素的时候,其对象元素个数大小会减少
  • 接下来,便会介绍部分 vector 中的函数,以便于让读者了解 vector 容器的用法

首先 vector 容器,是这样定义的

 vector<int> pos;
//此定义了一个整型的空的 vector 容器,名称为pos vector<int>::iterator iterpos;
//此定义了一个整型的迭代器,名称为iterpos 下面,介绍 vector 中的构造函数 - vector()
//这是创建一个空的 vector 容器
exanple : vector<int> pos(); - vector(int nSize)
//这是创建一个包含nSize个数的vector容器
exanple : vector<int> pos( nSize ); - vector(int nSize, const T& t)
//创建一个大小为 nSize,初值为 t 的vector容器
exanple : vector<int> pos( nSize, t ); - vector(const vector& )
//从另一个 vector 中复制该 vector 容器
exanple : vector<int> pos1( pos2 );
( pos2为整型的vector容器 )

其次 vector 容器中,存在增加,删除,以及其他用途的函数

  • 首先,我们来讲一下增加函数

void push_back(const T& x);

此函数是向向量后边添加一个元素,其用法为
pos.push_back(3);
pos为vector申请的一维的一个容器,向后边推进的数据为3

iterator insert(iterator it, const T & x);

此函数是向容器中的某一元素前添加x元素,iterator为迭代器,相当于vector中使用的指针

void insert(iterator it, int n, const T& x);

向容器中的某一元素前增加相同的元素x,增加的数量为n个

void insert(iterator it, const_iterator first, const_iterator last);

该元素是向向量中的某一元素it前插入另一个相同类型向量的[ first, last )间的数据。
  • 其次,我们来讲一下删除函数

iterator erase(iterator it);

删除向量中的某一元素,利用迭代器,定位到vector容器中的位置,从而删除该元素。

iterator erase(iterator first, iterator last);

删除向量中[first, last)中的元素,利用迭代器,定位两个位置。
然后调用函数,从而删除该容器从first到last中的元素。

void clear();

此函数是删除向量/容器中的所有元素,为程序结束时,调用释放内存
  • 再者,我们来讲一下 vector 中的其他函数

bool empty() const;

此函数为判空函数,判断该向量/容器是否为空,如果为空,返回true,如果是非空,返回false(布尔值)

void swap(vector &);

此函数为交换两个同类型向量的数据

vector 可以用来动态申请二维数组,类似功能和二维数组调用类似,以下便是一个简短的例子


#include<iostream>
#include<cstdlib>
#include<vector>
using namespace std; //函数声明
void _Arry(vector<vector<int>>& arry, int line, int column); int main()
{
int column, line;
cin >> line >> column; //在此地方,声明了以为数组arry,有line个
vector< vector < int > > arry(line); //此地方,用申请来的arry数组,再次申请空间,申请column个,resize分配空间,创建对象
for (int i = 0; i < line; i++)
arry[i].resize(column); _Arry(arry, line, column); //清理申请来的空间,如何申请便如何清理
for (int i = 0; i < line; i++)
arry[i].clear();
arry.clear(); return 0;
} //调用函数调用申请的二维数组
void _Arry(vector<vector<int>>&arry,int line,int column)
{
for (int i = 0; i < line; i++)
for (int j = 0; j < column; j++)
arry[i][j] = 8; for (int i = 0; i < line; i++)
{
for (int j = 0; j < column; j++)
cout << arry[i][j] << " ";
cout << endl;
}
}

部分图示如下:

- 向量本身

- 添加向量

- 删除向量

- 添加同一类型的多个向量


Vector 容器简单介绍的更多相关文章

  1. [C++ STL] 各容器简单介绍

    什么是STL? 1.STL(Standard Template Library),即标准模板库,是一个高效的C++程序库. 2.包含了诸多常用的基本数据结构和基本算法.为广大C++程序员们提供了一个可 ...

  2. vector容器经常用法

    容器简单介绍 定义及初始化 末尾插入元素 遍历 size 函数是能够动态添加的 通过下标操作添加改变vector内容不是安全的操作 仅能对已存在元素进行下标操作不存在会crash 将元素一个容器复制给 ...

  3. vector,list,deque容器的迭代器简单介绍

    我们知道标准库中的容器有vector,list和deque.另外还有slist,只不过它不是标准容器.而谈到容器,我们不得不知道进行容器一切操作的利器---迭代器.而在了解迭代器之前,我们得先知道每个 ...

  4. c++ 头文件 及 sort 和 vector简单介绍

    c++  sort :http://www.16kan.com/post/997260.html http://wenku.baidu.com/view/e064166daf1ffc4ffe47ac6 ...

  5. STL vector使用方法介绍

    介绍 这篇文章的目的是为了介绍std::vector,怎样恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...

  6. C++移动构造函数以及move语句简单介绍

    C++移动构造函数以及move语句简单介绍 首先看一个小例子: #include <iostream> #include <cstring> #include <cstd ...

  7. C++map类型 之 简单介绍

    一:map的前世今生 (1)从关联容器与顺序容器说起.关联容器通过键(key)存储和读取元素.而顺序容器则通过元素在容器中的位置顺序存储和訪问元素(vector,queue,stack,list等). ...

  8. 带你深入理解STL之Vector容器

    C++内置了数组的类型,在使用数组的时候,必须指定数组的长度,一旦配置了就不能改变了,通常我们的做法是:尽量配置一个大的空间,以免不够用,这样做的缺点是比较浪费空间,预估空间不当会引起很多不便. ST ...

  9. STL之vector容器详解

    vector 容器 vector是C++标准模版库(STL,Standard Template Library)中的部分内容.之所以认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单的说: ...

随机推荐

  1. 从零开始Spring项目

    Spring Boot是什么 SpringBoot是伴随着Spring4.0诞生的: 从字面理解,Boot是引导的意思,SpringBoot帮助开发者快速搭建Spring框架: SpringBoot帮 ...

  2. HDU - 5950 Recursive sequence(二项式+矩阵合并+矩阵快速幂)

    Recursive sequence Farmer John likes to play mathematics games with his N cows. Recently, they are a ...

  3. 在GridView的RowDataBound事件中获取某行某列的值!

    protected void gdvOrders_RowDataBound(object sender, GridViewRowEventArgs e)   {               if (e ...

  4. 程序员必备,C#各类项目、开源项目插件资料收藏

    一.AOP框架     Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种部署方面 ...

  5. 数据库路由中间件MyCat - 源代码篇(9)

    此文已由作者张镐薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 3. 连接模块 3.5 后端连接 3.5.1 后端连接获取与负载均衡 上一节我们讲了后端连接的基本建立和响应 ...

  6. SCUT - 157 - CC和他的GCD - 容斥原理

    https://scut.online/p/157 鉴于多年(都没几个月)搞数论的经验,这种时候枚举g肯定是对的. 那么肯定是要莫比乌斯函数作为因子,因为很显然? 但是为什么要搞个负的呢?其实是因为这 ...

  7. UIPI VS与Win7 共舞:用户界面特权隔离

    http://tech.it168.com/a2009/0924/737/000000737968.shtml [IT168 专稿]在上文中,我们介绍了操作系统服务的Session 0隔离,通过Ses ...

  8. 6.Python初窥门径(小数据池,集合,深浅拷贝)

    Python(小数据池,集合,深浅拷贝) 一.小数据池 什么是小数据池 小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址 小数据池 is和==的区别 == 判断等号俩边的 ...

  9. 联盟链FISCO BCOS权限控制一览

    FISCO BCOS是完全开源的联盟区块链底层技术平台,由金融区块链合作联盟(深圳)(简称金链盟)成立开源工作组通力打造.开源工作组成员包括博彦科技.华为.深证通.神州数码.四方精创.腾讯.微众银行. ...

  10. 深入浅出面向对象分析与设计读书笔记一&吉他搜索案例&吉他特性锚点集中&委托&重用&业务阶段&需求列表&用例

    案例:吉他搜索Guitar Inventory GuitarSpec需求变化:增加吉他弦数特性原始程序需要的变化: 1.修改GuitarSpec,构造,成员,getter 2.修改Guitar,构造, ...