vector是C++标准模板库,它是一个多功能、能够操作多种数据结构和算法的模板类。vector是一个容器,能够像容器一样存放各种类型的对象。vector是一个能够存放任意类型的动态数组,能够增加和删除元素,可以完全替代C语言风格的动态数组,由于vector能够自动的管理内存,我们不需要考虑内存的增长和释放、具有很好的安全性。

vector的初始化

//定义具有10个整型元素的向量
//(尖括号为元素类型名,它可以是任何合法的数据类型),
//不具有初值,其值不确定
vector<int>a(10);//定义具有10个整型元素的向量,且给出的每个元素初值为1
vector<int>a(10,1);//用向量b给向量a赋值,a的值完全等价于b的值
vector<int>a(b);//将向量b中从0-2(共三个)的元素赋值给a,a的类型为int型
vector<int>a(b.begin(),b.begin+3);//从数组中获得初值
int b[7]={1,2,3,4,5,6,7};
vector<int> a(b,b+7);

vector的常用内置函数使用

vector::begin/end

#include <iostream>
#include <vector>
using namespace std;
int main ()
{// vector::begin/endstd::vector<int> myvector;for (int i=1; i<=5; i++) myvector.push_back(i*2); //generate a vector[1,2,3,4,5]std::cout<<"size of vector is:\n"<<myvector.size()<<endl;std::cout<<"back of vector is:\n" <<myvector.back()<<endl;vector<int>::iterator v = myvector.begin()+1;//迭代器指向myvector的第二个元素std::cout<<"begin of vector is:\n" <<*v <<endl;//打印这个指针变量for (std::vector<int>::iterator it = myvector.begin() ; it < myvector.end(); it++)std::cout << ' ' << *it;std::cout << '\n';return 0;
}

output is:

size of vector is:
5
back of vector is:
10
begin of vector is:
42 4 6 8 10

// vector :: assign

std::vector<int> first;std::vector<int> second;std::vector<int> third;first.assign (7,100);             // 7 ints with a value of 100std::vector<int>::iterator it;it=first.begin()+1;second.assign (it,first.end()-1); // the 5 central values of firstint myints[] = {1776,7,4};third.assign (myints,myints+3);   // assigning from array.from 1776 to *1776 +3, three elementsstd::cout << "Size of first: " << int (first.size()) << '\n';for (std::vector<int>::iterator itf = first.begin() ; itf < first.end(); itf++){std::cout <<" "<<*itf;}std::cout<<endl;std::cout << "Size of second: " << int (second.size()) << '\n';for (std::vector<int>::iterator its = second.begin() ; its < second.end(); its++){std::cout <<" "<<*its;}std::cout<<endl;std::cout << "Size of third: " << int (third.size()) << '\n';for (std::vector<int>::iterator itt = third.begin() ; itt < third.end(); itt++){std::cout <<" "<<*itt;}std::cout<<endl;return 0;

output is:

Size of first: 7100 100 100 100 100 100 100
Size of second: 5100 100 100 100 100
Size of third: 31776 7 4

vector::at

at 和 operator[]具有一样的access elements 作用,但是at能够抛出out of range exception,所以推荐使用at,而不是运算符 [ ]

std::vector<int> myvector (4);   // 10 zero-initialized ints// assign some values:// or access some element;for (unsigned i=0; i<myvector.size(); i++)myvector.at(i)=i*i;std::cout << "myvector contains:";for (unsigned i=0; i<myvector.size(); i++)std::cout << ' ' << myvector.at(i);std::cout << '\n';return 0;

output is:

myvector contains: 0 1 4 9

vector::back

return the last element
myvector.back()

vector::size/capacity/max_size

size就是当前的vector长度,capacity是容器长度,一定是大于等于这个size的,当然当vector增长到capacity长度时不是说就塞不下了,capacity会继续allocate增大分配内存空间,而可以增大到的最大的理论极限就是max_size.

    std::vector<int> myvector;// set some content in the vector:for (int i=0; i<100; i++) myvector.push_back(i);std::cout << "size: " << (int) myvector.size() << '\n';std::cout << "capacity: " << (int) myvector.capacity() << '\n';std::cout << "max_size: " << (int) myvector.max_size() << '\n';return 0;
size: 100
capacity: 128
max_size: 1073741823

vector::vector::cbegin/cend

用于访问vector首尾元素,但无法修改该值

vector::clear

clear vector content

myvector.clear();

vector::data

指针指向vector首位

  std::vector<int> myvector (5);int* p = myvector.data();*p = 10;++p;*p = 20;p[2] = 100;std::cout << "myvector contains:";for (unsigned i=0; i<myvector.size(); ++i)std::cout << ' ' << myvector[i];std::cout << '\n';return 0;

output is:

myvector contains: 10 20 0 100 0

vector::empty

// Returns whether the vector is empty
//  (i.e. whether its size is 0).
myvector.empty()

vector::erase

  std::vector<int> myvector;// set some values (from 1 to 10)for (int i=1; i<=10; i++) myvector.push_back(i);// erase the 6th elementmyvector.erase (myvector.begin()+5);// erase the first 3 elements:myvector.erase (myvector.begin(),myvector.begin()+3);std::cout << "myvector contains:";for (unsigned i=0; i<myvector.size(); ++i)std::cout << ' ' << myvector[i];std::cout << '\n';return 0;

output is:

myvector contains: 4 5 7 8 9 10

vector:: front/back

// return the first and the last elements.
//unlike vector::begin/end, front/back returns direct reference.myvector.front()myvector.back()

vector::insert

//在a的第一个元素(从第0个算起)位置插入数值5,
a.insert(a.begin()+1,5);
//在a的第一个元素(从第0个算起)位置插入3个数,其值都为5
a.insert(a.begin()+1,3,5);
//b为数组,在a的第一个元素(从第0个元素算起)的位置插入b的第三个元素到第5个元素(不包括b+6)
a.insert(a.begin()+1,b+3,b+6);
   std::vector<int> myvector (3,100);//[100,100,100]std::vector<int>::iterator it;it = myvector.begin();it = myvector.insert ( it , 200 );[200,100,100,100]myvector.insert (it,2,300);[300,300,200,100,100,100]// "it" no longer valid, get a new one:it = myvector.begin();std::vector<int> anothervector (2,400);myvector.insert (it+2,anothervector.begin(),anothervector.end());//[300,300,400,400,200,100,100,1000]int myarray [] = { 501,502,503 };myvector.insert (myvector.begin(), myarray, myarray+3);//[501,502,503,300,300,400,400,200,100,100,100]std::cout << "myvector contains:";for (it=myvector.begin(); it<myvector.end(); it++)std::cout << ' ' << *it;std::cout << '\n';return 0;
}

output is:

myvector contains: 501 502 503 300 300 400 400 200 100 100 100

vector::pop_back/push_back

delete and add element at the end

vector::reserve

//increase vector capacity to n
myvector::reserve(n)

vector::resize

  std::vector<int> myvector;// set some initial content:for (int i=1;i<10;i++) myvector.push_back(i);myvector.resize(5);//[1,2,3,4,5]myvector.resize(8,100);//[1,2,3,4,5,100,100,100]myvector.resize(12);//[1,2,3,4,5,100,100,100,0,0,0,0]std::cout << "myvector contains:";for (int i=0;i<myvector.size();i++)std::cout << ' ' << myvector[i];std::cout << '\n';return 0;

output is:

myvector contains: 1 2 3 4 5 100 100 100 0 0 0 0

vector::shrink_to_fit

// shrink capacity to fit current vector size
myvector.shrink_to_fit()

C++ vector库学习笔记相关推荐

  1. pbds库学习笔记(优先队列、平衡树、哈希表)

    目录 pbds库学习笔记(优先队列.平衡树.哈希表) 前言 概述 priority_queue优先队列 概述 参数 堆的基本操作的函数 对比STL新增函数 modify修改 Dijkstra最短路径演 ...

  2. Boost库学习笔记(二)算法模块-C++11标准

    Boost库学习笔记(二)算法模块-C++11标准 一.综述 Boost.Algorithm是一系列人通用推荐算法的集合,虽然有用的通用算法很多,但是为了保证质量和体积,并不会将太多通用算法通过审查测 ...

  3. Eigen库学习笔记(四)Eigen用于三维张量

    Eigen库学习笔记(四)Eigen用于三维张量 1.示例: 2.3维张量 3.固定大小矩阵TensorFixedSize 4.常用函数API 5.矩阵乘法与广播机制 Tensor的矩阵乘法操作 Te ...

  4. Eigen库学习笔记(五)张量计算

    Eigen库学习笔记(五)张量计算 1.规约操作 2.最值与索引 3.按索引取值 Array of indices 4.类似 where的功能,生成mask 5.reshape 改变形状元素个数不变 ...

  5. Eigen库学习笔记(十三)Eigen实现softmax

    Eigen库学习笔记(十三)Eigen实现softmax 1.pytorch中的softmax 2.Eigen实现softmax 1.pytorch中的softmax 示例: import torch ...

  6. python xlwings 切片_Python xlwings库学习笔记(1)

    Python xlwings库学习笔记(1) Python是最近几年很火的编程语言,被办公自动化的宣传吸引入坑,办公自动化必然绕不开Excel的操作,能操作Excel的库有很多,例如: xlrd xl ...

  7. python标准库学习笔记

    原创:python标准库学习笔记 数据结构 bisect 模块里实现了一个向列表插入元素时也会顺便排序的算法. struct - 二进制数据结构:用途:在 Python 基本数据类型和二进制数据之间进 ...

  8. 深度学习常用python库学习笔记

    深度学习常用python库学习笔记 常用的4个库 一.Numpy库 1.数组的创建 (1)np.array() (2)np.zeros() (3)np.ones() (4)np.empty() (5) ...

  9. Huggingface Transformers库学习笔记(二):使用Transformers(上)(Using Transformers Part 1)

    前言 本部分是Transformer库的基础部分的上半部分,主要包括任务汇总.模型汇总和数据预处理三方面内容,由于许多模型我也不太了解,所以多为机器翻译得到,错误再所难免,内容仅供参考. Huggin ...

最新文章

  1. Windows中现在有独立的Linux文件夹系统
  2. How to install MinGW-w64 and MSYS2?
  3. 程序集信息设置.net
  4. python filter过滤器的使用_Python filter过滤器原理及实例应用
  5. DBA一族九阳神功秘籍
  6. 如何修改was的java路径_在eclipse中修改tomcat的部署路径操作
  7. js排序算法详解-基数排序
  8. 连接虚机中的mysql服务
  9. 【java与移动设备】CH06 资源的使用
  10. 显示屏连接控制卡超时_天津塘沽、开发区怎么更改led电子显示屏字幕,如何修LED屏...
  11. java 实现用户登陆代码_Java Web用户登录实例代码
  12. 什么是竞品分析?竞品分析全流程解析
  13. 与计算机专业的社会学的论文,计算机专业研究生论文致谢词
  14. 【LeetCode力扣】青蛙跳台阶问题,一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
  15. 安装office2021时报错,无法卸载以前office版本残留项
  16. AppStore 技术服务支持
  17. https 是什么意思?怎么把http改成https?
  18. qpython3手机版turtle_Python的画图模块turtle使用详解
  19. DA LAO:SpringBoot讲述 快速构建微服务体系。
  20. python判断电话号码是否合理_Python正则匹配判断手机号是否合法的方法

热门文章

  1. navigator工具_推荐!11个令人惊叹的前端开发工具,值得拥有
  2. html条件查询的页面,如何在 url 中记录页面搜索条件
  3. Linux通过SSH实现免密登录
  4. 微信公众号sae服务器搭建,SAE 搭建微信公众平台
  5. php 10进制位数保持,php 任意进制的数转换成10进制功能实例
  6. ccie计算机网络英语,最新版CCIE Voice 语音方向 WOLF实验全套语音课程(含版本)...
  7. c语言中打印ipv6地址,c-来自任何有效地址的ipv4和ipv6
  8. NET 对象生命周期
  9. tortoiseGit的SHH秘钥设置
  10. 用Node-Inspector调试NodeJs程序