zoukankan      html  css  js  c++  java
  • C++ 简析容器Vector

    向量(Vector)是一个封装了动态大小数组的顺序容器(Sequence Container)。跟任意其它类型容器一样,它能够存放各种类型的对象。可以简单的认为,向量是一个能够存放任意类型的动态数组。

    一、基本概念

    向量(Vector)是一个封装了动态大小数组的顺序容器(Sequence Container)。跟任意其它类型容器一样,它能够存放各种类型的对象。可以简单的认为,向量是一个能够存放任意类型的动态数组。

    二、容器特性

    1. 顺序序列

    顺序容器中的元素按照严格的线性顺序排序。可以通过元素在序列中的位置访问对应的元素。

    2. 动态数组

    支持对序列中的任意元素进行快速直接访问,甚至可以通过指针算述进行该操作。操供了在序列末尾相对快速地添加/删除元素的操作。

    3. 能够感知内存分配器的(Allocator-aware)

    容器使用一个内存分配器对象来动态地处理它的存储需求。

    三、基本函数

    1.构造函数

    • vector():创建一个空vector
    • vector(int nSize):创建一个vector,元素个数为nSize
    • vector(int nSize,const t& t):创建一个vector,元素个数为nSize,且值均为t
    • vector(const vector&):复制构造函数
    • vector(begin,end):复制[begin,end)区间内另一个数组的元素到vector中

    2.增加函数

    • void push_back(const T& x):向量尾部增加一个元素X
    • iterator insert(iterator it,const T& x):向量中迭代器指向元素前增加一个元素x
    • iterator insert(iterator it,int n,const T& x):向量中迭代器指向元素前增加n个相同的元素x
    • iterator insert(iterator it,const_iterator first,const_iterator last):向量中迭代器指向元素前插入另一个相同类型向量的[first,last)间的数据

    3.删除函数

    • iterator erase(iterator it):删除向量中迭代器指向元素
    • iterator erase(iterator first,iterator last):删除向量中[first,last)中元素
    • void pop_back():删除向量中最后一个元素
    • void clear():清空向量中所有元素

    4.遍历函数

    • reference at(int pos):返回pos位置元素的引用
    • reference front():返回首元素的引用
    • reference back():返回尾元素的引用
    • iterator begin():返回向量头指针,指向第一个元素
    • iterator end():返回向量尾指针,指向向量最后一个元素的下一个位置
    • reverse_iterator rbegin():反向迭代器,指向最后一个元素
    • reverse_iterator rend():反向迭代器,指向第一个元素之前的位置

    5.判断函数

    • bool empty() const:判断向量是否为空,若为空,则向量中无元素

    6.大小函数

    • int size() const:返回向量中元素的个数
    • int capacity() const:返回当前向量所能容纳的最大元素值
    • int max_size() const:返回最大可允许的vector元素数量值

    7.其他函数

    • void swap(vector&):交换两个同类型向量的数据
    • void assign(int n,const T& x):设置向量中第n个元素的值为x
    • void assign(const_iterator first,const_iterator last):向量中[first,last)中元素设置成当前向量元素

    8.看着清楚

    函数 功能
    1 push_back( ) 在数组的最后添加一个数据
    2 pop_back() 去掉数组的最后一个数据
    3 at 得到编号位置的数据
    4 begin 得到数组头的指针
    5 end 得到数组的最后一个单元+1的指针
    6 front 得到数组头的引用
    7 back 得到数组的最后一个单元的引用
    8 max_size 得到vector最大可以是多大
    9 capacity 当前vector分配的大小
    10 size 当前使用数据的大小
    11 resize 改变当前使用数据的大小,如果它比当前使用的大,者填充默认值
    12 reserve 改变当前vecotr所分配空间的大小
    13 erase 删除指针指向的数据项
    14 clear 清空当前的vector
    15 rbegin 将vector反转后的开始指针返回(其实就是原来的end-1)
    16 rend 将vector反转构的结束指针返回(其实就是原来的begin-1)
    17 empty 判断vector是否为空
    18 swap 与另一个vector交换数据

    四、二维Vector初始化

    //二维vector初始化
    vector< vector<int> > vt;//初始化一个 二维vector
    vector< vector<int> > vect(vt);//使用另一个 二维 vector 初始化当前二维vector
    vector< vector<int> > vec(row,vector<int>(column));//初始化一个 二维的vector 行row,列column,且值为0
    vector<vector<int> > visited(row,vector<int>(column,6));//初始化一个 二维vector 行row,列column ,且 值为data=6 自定义data;
    vector<vector<int> > vecto(row,vector<int>(vt[0].begin()+1,vt[0].begin()+3));////初始化一个 二维vector 行row,第二个参数为一维vector;

    五、排序

    vector<int> v;
    sort(v.begin(),v.end());

    //自定义排序
    auto compare = [](string sa, string sb){return sa+sb < sb+sa;};
    sort(numstr.begin(),numstr.end(),compare);
  • 相关阅读:
    How to function call using 'this' inside forEach loop
    jquery.validate.unobtrusive not working with dynamic injected elements
    Difference between jQuery.extend and jQuery.fn.extend?
    Methods, Computed, and Watchers in Vue.js
    Caution using watchers for objects in Vue
    How to Watch Deep Data Structures in Vue (Arrays and Objects)
    Page: DOMContentLoaded, load, beforeunload, unload
    linux bridge
    linux bridge
    EVE-NG网卡桥接
  • 原文地址:https://www.cnblogs.com/guoben/p/13339275.html
Copyright © 2011-2022 走看看