在C中,有很多东西需要自己实现。C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能。

具体容器链接:setstringmapqueuepriority_queuestackpair

1、vector的用法

  vector:向量,这里叫“变长数组”,长度根据需要而自动改变的数组。有时会碰到普通数组会超过内存的情况,可以使用vector解决。而且,vector可以用来以邻接表的方式存储图,可以解决当节点数太多,无法使用邻接矩阵,又害怕使用指针实现邻接表的时候,使用很简单。

  使用vector,需要添加头文件,#include<vector>,还要头文件下加入using namespace std;

1.1、vector的定义

vector<typename> name;

相当于定义了一个一维数组name[SIZE],只不过size可以根据需要进行变化,比较节省空间,也就是变长数组

typename:任何基本类型,int,char,double,结构体,STL容器vector,set,queue等。

如果typename是STL容器,定义的时候要在>>之后加上空格,如果不加空格,编译器就把它认为是位操作。

vector<int> stu;
vector<double> stu;
vector<char> stu;
vector<Node> stu;//Node是结构体类型
vector<vector<int>> name;

二维数组的定义:一维是一个数组的数组

vector<typename> Arrayname[arraySize]
/*Arrayname[]的每一个元素都是一个vector,可以理解为两个维都是可变长的二维数组*/
写法一:vector<int> vi[100];//一维长度已经固定为arraySize
vi[0]~vi[99]中每一个都是一个vector容器。
写法二:vector<vector<int>> vi//区别:这个两个维度是变长的

1.2、vector容器内元素的访问

  vector访问方式:下标访问、迭代器访问。

  1.2.1、下标访问

  和访问普通数组一样,下标从0~size()-1。

  比如定义的:vector<typename> vi,使用vi[index](vi[0],vi[1])。

  1.2.2、通过迭代器访问

  迭代器(iterator)理解为类似指针的东西。

  定义:vector<typename>::iterator it;//it是一个迭代器变量。

#include<stdio.h>
#include<vector>
using namespace std;
int main()
{
vector<int> vi;
for(int i=;i<;i++)
{
vi.push_back(i);
}
vector<int>::iterator it=vi.begin();//vi.begin()是vi的首元素地址,用迭代器变量it指向这个地址
for(int i=;i<;i++)
{
printf("%d\n",*(it+i));//输出vi[i];
}
return ;
}

注:vi[i]与*(vi.begin()+i)等价

end()函数:并不是取vi的尾元素地址,而是取尾元素的下一个地址。就相当于左闭右开区间。

#include<stdio.h>
#include<vector>
using namespace std;
int main()
{
vector<int> vi;
for(int i=;i<;i++)
{
vi.push_back(i);
}
vector<int>::iterator it=vi.begin();//vi.begin()是vi的首元素地址,用迭代器变量it指向这个地址
for(int i=;i<;i++)
{
printf("%d\n",*(it+i));//输出vi[i];
}
//使用begin(),end()函数,访问
for(vector<int>::iterator it=vi.begin();it!=vi.end();it++)
{
printf("%d\n",*it);
}
return ;
}

注:在常用STL容器中,只有vector和string才可以使用vi.begin()+i这种迭代器加整数的写法,因为他们两个看做数组的下标的访问方式。

1.3、vector常用函数

  1.3.1、push_back()函数

push_back(x)就是在vector后面添加一个元素x,时间复杂度为O(1)。

  1.3.2、pop_back()函数

pop_back(x)就是删除vector的尾元素x,时间复杂度为O(1)。

  1.3.3、size()函数

用来获得vector中元素的个数,时间复杂度为O(1)。

  1.3.4、clear()函数

用来清空vector所有的元素,时间复杂度为O(N),N为元素总个数。

  1.3.5、insert()函数

用insert(it,x)往vector的任意迭代器it初传入一个元素x。时间复杂度为O(N)。

  1.3.6、erase()函数

用erase()函数删除单个元素,或者一个区间的元素

#include<stdio.h>
#include<vector>
using namespace std;
int main()
{
vector<int> vi;
for(int i=;i<;i++)
{
vi.push_back(i);//jpush_back()函数应用
}
vi.pop_back(i);//删除vi的尾部元素4
int i=vi.size();//size()返回的unsingned类型
vi.clear();//清空vector所有元素
vi.insert(vi.begin()+,);//将23插入vi[2]的位置
vi.erase(vi.begin()+);//删除单个元素vi[1];
vi.erase(vi.begin()+,vi.begin()+);//删除vi[1],vi[2],左闭右开区间
return ;
}

1.4、vector常见用途

  1.4.1、存储数据

vector本身可以作为数组使用,当元素个数不确定的时候,可以很好地节省空间。

有些时候需要把部分数据输出在同一行,用空格隔开数据。由于数据的个数不知道,

可以使用vector记录所有的需要输出的数据,然后一次性输出。

  1.4.2、用邻接表存储图

可以使用vector实现邻接表,避免使用指针的邻接链表。

2018-09-25 14:24:20                                                                 @author:Foreordination

C++标准模板库(STL)之Vector的更多相关文章

  1. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  2. C++的标准模板库STL中实现的数据结构之顺序表vector的分析与使用

    摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解.即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第一篇,主要针对线性表中的顺序表(动 ...

  3. C++ 标准模板库(STL)

    C++ 标准模板库(STL)C++ STL (Standard Template Library标准模板库) 是通用类模板和算法的集合,它提供给程序员一些标准的数据结构的实现如 queues(队列), ...

  4. STL学习系列之一——标准模板库STL介绍

    库是一系列程序组件的集合,他们可以在不同的程序中重复使用.C++语言按照传统的习惯,提供了由各种各样的函数组成的库,用于完成诸如输入/输出.数学计算等功能. 1. STL介绍 标准模板库STL是当今每 ...

  5. 标准模板库--STL

    标准模板库STL 1.泛型程序设计 C++ 语言的核心优势之一就是便于软件的重用 C++中有两个方面体现重用: 1.面向对象的思想:继承和多态,标准类库 2.泛型程序设计(generic progra ...

  6. C++的标准模板库STL中实现的数据结构之链表std::list的分析与使用

    摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解,即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第二篇.主要针对线性表中的链表 ST ...

  7. 标准模板库(STL)学习探究之stack

    标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string

  8. 实验8 标准模板库STL

    一.实验目的与要求: 了解标准模板库STL中的容器.迭代器.函数对象和算法等基本概念. 掌握STL,并能应用STL解决实际问题. 二.实验过程: 完成实验8标准模板库STL中练习题,见:http:// ...

  9. C++ 标准模板库STL 队列 queue 使用方法与应用介绍

    C++ 标准模板库STL 队列 queue 使用方法与应用介绍 queue queue模板类的定义在<queue>头文件中. 与stack模板类很相似,queue模板类也需要两个模板参数, ...

  10. 【c++】标准模板库STL入门简介与常见用法

    一.STL简介 1.什么是STL STL(Standard Template Library)标准模板库,主要由容器.迭代器.算法.函数对象.内存分配器和适配器六大部分组成.STL已是标准C++的一部 ...

随机推荐

  1. Machine Learning 第三周

    ML week3 逻辑回归 Logistic Function h_\theta(x)=g(\theta^Tx) g(t)=\frac{1}{1+e^{-z}} 当t大于0, 即下面公式成立时,y=1 ...

  2. h5页面实战——与andriod和ios的交互

    首先需要我们h5页面需要做一些匹配.比如:如何判断当前手机是andriod还是ios, andriod攻城狮和ios工程师,一般会定义事件的方法.我们套用他们方法就可以了. 那么为什么我要写这个随笔呢 ...

  3. mysql知识点汇总

    1. 数据库的安装 2. 数据库设计需要注意什么 3. SQL语句优化 4. 怎样处理慢查询? 5. 怎样更好的利用数据库索引? 6. 事务隔离级别有哪些?怎么实现的? 7. 数据库锁有哪些? 8. ...

  4. HTTP请求中GET和POST的区别

    一.原理区别 一般我们在浏览器输入一个网址访问网站都是GET请求;再FORM表单中,可以通过设置Method指定提交方式为GET或者POST提交方式,默认为GET提交方式. HTTP定义了与服务器交互 ...

  5. 小白のjava实现wc.exe功能

    GitHub地址 项目完成情况 基本功能列表(已实现) wc.exe -c file.c     //返回文件 file.c 的字符数 wc.exe -w file.c    //返回文件 file. ...

  6. Winform Chart 控件读取datatable后显示图表

    private void Button2_Click(object sender, EventArgs e) { DataTable table = new DataTable(); this.cha ...

  7. Automatically populating $HTTP_RAW_POST_DATA is deprecated......

    Automatically populating $HTTP_RAW_POST_DATA is deprecated... 1 这个问题和PHP版本有关系,PHP 5.6已经废弃了$HTTP_RAW_ ...

  8. 误删除(重命名)libc.so.6的处理方法

    LD_PRELOAD=/lib64/libc-2.12.so ln -s /lib64/libc-2.12.so /lib64/libc.so.6 ssh尚未断开的话可以直接这样操作,断开之后可以用l ...

  9. 大佬是怎么思考设计MySQL优化方案的?

    在进行MySQL的优化之前,必须要了解的就是MySQL的查询过程,很多查询优化工作实际上就是遵循一些原则,让MySQL的优化器能够按照预想的合理方式运行而已. 一.优化的哲学 注:优化有风险,涉足需谨 ...

  10. 线程池如何复用一个线程-- ThreadPoolExecutor的实现(未完)

    任务是一组逻辑工作单元,而线程则是使任务异步执行的机制.在Java中,Runnable对象代表一个任务,Thread对象负责创建一个线程执行这个任务. 前提:1. 程序需要处理大量任务 2. 任务的执 ...