1、创建vector容器:

std::vector<int> data;

std::vector<int> data(20);大小20,自动赋值为0

std::vector<int> data(20,9);大小20,并且初始值为9

表示创建vector容器,其容器内的数据类型为int类型。该初始化时,因为容器内没有元素,因而没有分配空间。可以调用reserve()函数增加容器的容量。

2、vector容器的容量和大小

容量:在不分配更多内存的情况下可以保存的最多元素个数。

大小:容器实际所保存的元素个数。

std::vector<int > data;

data.capacity();得到容量大小。

data.size();得到容器实际大小

容器的大小可以使用resize()来改变容器大小。reserve()函数增加容量。

3、访问元素

使用方括号,在方括号中使用引用。下标默认从0开始。使用push_back(),insert(),emplace()插入新的元素。为了安全,防止出现数组下标越界。尽可能使用at()去访问vector元素。

4、增加元素

使用push_back()函数,在序列的末尾添加一个元素。使用emplace_back()也可以达到同样的效果

push_back()和emplace_back()的区别:emplace_back()直接调用构造函数。而push_back()则需要生成对象,然后调用对象构造函数。

5、插入元素

使用emplace()和insert()插入元素

iterator insert( iterator loc, const TYPE &val );
void insert( iterator loc, size_type num, const TYPE &val );
void insert( iterator loc, input_iterator start, input_iterator end );
insert() 函数有以下三种用法:
在指定位置loc前插入值为val的元素,返回指向这个元素的迭代器,
在指定位置loc前插入num个值为val的元素
在指定位置loc前插入区间[start, end)的所有元素 .

6、删除元素

使用clear()来删除元素,但是该操作并没有改变容器的容量;使用pop_back()函数来删除尾部元素。

使用erase()来删除容器内的一个或者多个元素;remove()可以删除匹配特定特征值的一段元素。

参考代码:

#include <iostream>
#include <vector>
using namespace std;

int main()
{
    cout << "vector 使用示例" << endl;
    cout << "vector 创建"<<endl;
    cout << "----------------------------"<<endl;
    //创建vector的三种方式
    vector<int> data;
    vector<);
    vector<,);
    cout << "----------vector容量和大小-----------"<<endl;
    cout << "容量"<< data1.capacity() << "大小"<<data1.size()<<endl;
    cout << "容量"<< data2.capacity() << "大小"<<data2.size()<<endl;
     data1.reserve();
     cout << data1.capacity()<<endl;
     data1.resize();
     cout<< data1.size() << "容量"<<data1.capacity()<<endl;
     cout<< "-----------访问元素----------"<<endl;
     cout << data2.at() <<]<<endl;
     cout << data2.front() << " " << data2.back();
     cout << "-----------增加元素---------" <<endl;
     data2.push_back();
     data2.emplace_back();
     cout << data2.back()<<endl;
     cout << "-------插入元素-------"<<endl;
     vector<string> words {"one","two","three"};
     auto iter = words.emplace(++begin(words),,'A');
     cout << words.at()<<*iter;
     //insert
     auto iter1 = words.insert(++std::begin(words),"twowwwww");
     cout    << *iter1<<endl;
     cout << "----- 删除元素---------" <<endl;
     //words.clear();//清楚所有元素,不改变容量
     words.pop_back();
     cout << *(words.end()-)<<endl;
     //erase()删除一个或者多个元素
     //remove()删除匹配特定值的一段
     //std::remove(begin(words),end(words),"two");
     cout << words.back()<<endl;
    ;
 }

vector使用小结的更多相关文章

  1. c++第十四天

    <c++ primer, 5E> 第91页到第94页,笔记: 1.vector支持的操作. v.empty().v.size().v.push_back(t).v[n] 2.试图通过下标访 ...

  2. STL中vector小结

    ()使用vector之前必须包含头文件<vector>:#include<vector> ()namespace std{ template <class T, clas ...

  3. C++中标准容器Vector,元素操作.insert()小结

    insert() 函数有以下三种用法: iterator insert( iterator loc, const TYPE &val );  //在指定位置loc前插入值为val的元素,返回指 ...

  4. vector的用法小结(待补全

    1.vector的好处 支!持!删!除! 节!省!内!存! 2.一点基础的小操作 ①插入操作:v.push_back(x) 在尾部插入元素x: ②删除操作 : v.erase(x)删除地址为x的元素 ...

  5. ?:,reverse,vector的基本小结

    #include <cstdio> //此代码为网上所复制 #include <iostream> #include <string> #include <s ...

  6. HTML最新标准HTML5小结

    写在前面 HTML5出来已经很久了,然而由于本人不是专业搞前端的,只知道有这个东西,具体概念有点模糊(其实就是一系列标准规范啦):因此去年(2015.11.09),专门对HTML5做了个简单的小结,今 ...

  7. 学习RaphaelJS矢量图形包--Learning Raphael JS Vector Graphics中文翻译(一)

    (原文地址:http://www.cnblogs.com/idealer3d/p/LearningRaphaelJSVectorGraphics.html) 前面3篇博文里面,我们讲解了一本叫做< ...

  8. C++ typedef用法小结 (※不能不看※)

    C++ typedef用法小结 (※不能不看※) 第一.四个用途 用途一: 定义一种类型的别名,而不只是简单的宏替换.可以用作同时声明指针型的多个对象.比如:char* pa, pb; // 这多数不 ...

  9. 跟我一起学STL(2)——vector容器详解

    一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...

随机推荐

  1. 输出字符串中最长的单词 C# 算法

    要求: 设计一个算法从一片英语文章或者英语字符串里面输出其中最长的单词. Input: string     Output: string 尽可能多的设计测试用例来测试这个算法. 考虑空间和时间复杂度 ...

  2. JS中那些让人头昏眼花的弯子

    看别人在讨论,于是整理了下,大家来看看下面代码中1-11分别输出的答案是什么???(不要试过再说) var obj={ a:1, b:2, add:function(c,d){ console.log ...

  3. ubuntu16.04 linux 编译安装apache2.4.33

    下载软件包: wget http://mirror.bit.edu.cn/apache//httpd/httpd-2.4.33.tar.gz wget http://mirrors.tuna.tsin ...

  4. MySQL中使用连接查询

    连接查询: 将多张表(可以大于2张)进行记录的连接(按照某个指定的条件进行数据拼接): 最终结果是: 记录数有可能变化, 字段数一定会增加(至少两张表的合并)! 连接查询的意义: 在用户查看数据的时候 ...

  5. BZOJ5473: 仙人掌

    传送门 首先,所有连通块的个数的期望再减去每个点孤立的概率就是答案. 设 \(d_i\) 表示 \(i\) 的度数,那么每个点孤立的概率为 \(\frac{1}{2^{d_i}}\) 考虑计算所有连通 ...

  6. BZOJ4827: [Hnoi2017]礼物(FFT 二次函数)

    题意 题目链接 Sol 越来越菜了..裸的FFT写了1h.. 思路比较简单,直接把 \(\sum (x_i - y_i + c)^2\) 拆开 发现能提出一坨东西,然后与c有关的部分是关于C的二次函数 ...

  7. element-ui Progress、Badge、Alert组件源码分析整理笔记(四)

    Progress进度条组件 <template> <!--最外层--> <div class="el-progress" :class="[ ...

  8. MyEclipse tomcat jsk配置--- jvm blind 异常

    -Xms1200m -Xmx1200m -XX:PermSize=64M-XX:MaxPermSize=256m-XX:ReservedCodeCacheSize=48m-Dcom.sun.manag ...

  9. JavaScript中何时使用===,何时使用==

    建议尽量都使用===,原因如下: 一致性:使用==对一致性没有任何好处,那么为什么不避免使用呢. 简单和性能:一般来说,===是最简单的操作符,因为它不用进行类型转换.JavaScript引擎的性能参 ...

  10. List常用几种方式

    第一种,匹配俩个集合中相同的值 , , , , , , }; , , , , , , , , }; var C= listA.Intersect(listB); foreach (var item i ...