标准模板库中的向量(vector)
//C++数据结构与算法(第4版) Adam Drozdek 著 徐丹 吴伟敏<<清华大学出版社>>
头文件:#include<vector>
向量是最简单的STL容器,其数据结构与数组类似,占据着一个连续的内存块。由于内存位置是连续的,所以向量中的元素可以随机访问,访问向量中任何一个元素的时间也是固定的。存储空间的管理是自动的,当要将一个元素插入到已满的向量中时,会为向量分配一个更大的内存块,将向量中的元素复制进新的内存块,然后释放旧的内存块。所以,向量是一个灵活的数组,是能够动态改变自身大小的数组。
vector() //创建空向量
vector(size_type n, const T& el = T()) //用类型T的n个el副本创建一个向量(如果没有提供el,则使用默认的构造函数T())
vector(iterator first, iterator last) //用迭代器first和last指示范围中的元素构造一个向量
vector(const vector<T>& v) //复制构造函数
void assign(iterator first,iterator last) //删除向量中的所有元素,然后将迭代器first和last指示范围中的元素插入该向量。
void assign(size_type n, const T& el = T()) //删除向量中的所有元素,然后将el的n个副本插入该向量中。
T& at(size_type n) //返回向量中位置为n的元素
const T& at(size_type n) const //返回向量中位置为n的元素
T& back() //返回向量的最后一个元素
T& front() //返回向量的第一个元素
const T& front() const //返回向量的第一个元素
const T& back() const //返回向量的最后一个元素
iterator begin() //返回一个迭代器,该迭代器引用向量的第一个元素
iterator end() //返回一个迭代器,该迭代器位于向量的最后一个元素之后
const_iterator begin() const //返回一个迭代器,该迭代器引用向量的第一个元素
const_iterator end() const //返回一个迭代器,该迭代器位于向量的最后一个元素之后
size_type capacity() const //返回可以存储在向量中的元素数目
void clear() //清除向量中的所有元素
bool empty() const //如果向量不包括元素,则返回true,否则返回false
iterator erase(iterator i) //删除由迭代器i引用的元素,返回一个迭代器,引用被删除元素之后的元素
iterator erase(iterator first, iterator last) //删除迭代器first和last指示范围中的元素,返回一个迭代器,引用被删除的最后一个元素之后的元素
iterator insert(ierator i, const T& el = T()) //在迭代器i引用的元素之前出入el,并返回引用新插入元素的迭代器
void insert(iterator i, size_type n, const T& el) //在迭代器i引用的元素之前插入el的n个副本
void insert(iterator i, iterator first, iterator last) //在迭代器i引用的元素之前插入迭代器first和迭代器last指示的范围中的元素
size_type max_size() const //返回向量最大元素数
T& operator[] //下标运算符
const T& operator[] const //下标运算符
void pop_back() //删除向量的最后一个元素
void push_back(const T& el) //在向量的末尾插入el
reverse_iterator rbegin() //返回引用向量中最后一个元素的迭代器
const_reverse_iterator rbegin() const //返回引用向量中最后一个元素的迭代器
reverse_iterator rend() //返回引用向量中第一个元素之前的迭代器
const_reverse_iterator rend() const //返回引用向量中第一个元素之前的迭代器
void reserve(size_type n) //如果向量的容量小于n,该函数就为向量预留保存n项的足够空间
void resize(size_type n, const T& el = T()) //使向量保存n个元素,方法是:通过el再添加n-size()个位置,或者丢弃向量末尾溢出的size()-n个位置
size_type size() const //返回向量中的元素数量
void swap(vector<T>& v) //与另一个向量v交换内容
在 vector 容器中间添加(或删除)元素将使所有指向插入(或删除)点后面的元素的迭代器失效。
标准模板库中的向量(vector)的更多相关文章
- 8、泛型程序设计与c++标准模板库2、c++标准模板库中的容器
顺序容器类以逻辑线性排列方式存储元素,在这些容器类型中的元素在逻辑上被认为是连续的存储空间中存储的.顺序容器可用于存储线性群体. 在关联容器类中,元素的存储和检索基于关键字和元素与其他元素之间的关系, ...
- 8、泛型程序设计与c++标准模板库2.2向量容器
向量容器属于顺序容器,用于容纳不定长线性序列(即线性群体),提供对序列的快速随机访问(也称直接访问).这一点与c++语言支持的基本数组类型相同,但基本数据类型不是面向对象的.而面向对象的向量是动态结构 ...
- 标准模板库 STL 使用之 —— vector 使用 tricks
1. 从已有 vector(或数组)中复制 vector<int> a{....}; int an = a.size(); int half = an/2; vector<int&g ...
- 标准模板库中的队列(queue)
//C++数据结构与算法(第4版) Adam Drozdek 著 徐丹 吴伟敏<<清华大学出版社>> 队列容器默认由deque实现,用户也可以选择list容器来实现.如果用 ...
- 标准模板库中的栈(stack)
////C++数据结构与算法(第4版) Adam Drozdek 著 徐丹 吴伟敏<<清华大学出版社>> STL中的通用栈类实现为容器适配器:使用以指定方式运行的容器.栈容 ...
- STL(标准模板库) 中栈(stack)的使用方法
STL 中栈的使用方法(stack) 基本操作: stack.push(x) 将x加入栈stack中,即入栈操作 stack.pop() 出栈操作(删除栈顶),只是出栈,没有返回值 stack.t ...
- 标准模板库中的优先队列(priority_queue)
//C++数据结构与算法(第4版) Adam Drozdek 著 徐丹 吴伟敏<<清华大学出版社>> #include<queue> priority_queu ...
- 标准模板库中的链表(list)
//C++数据结构与算法(第4版) Adam Drozdek 著 徐丹 吴伟敏<<清华大学出版社>> 头文件:include<list> list() 创建一个 ...
- C++的标准模板库STL中实现的数据结构之顺序表vector的分析与使用
摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解.即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第一篇,主要针对线性表中的顺序表(动 ...
随机推荐
- 计算机二级-C语言-程序设计题-190112记录-结构体的遍历和结构体的数据的交换处理,文件的操作。
//程序设计题:学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能是:把分数低的学生数据放在b所指的数组中,注意:分数最低的学生可能不止一个,函数返回 ...
- js中ES6的Set的基本用法
ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. const s = new Set(); [2,3,5,4,5,2,2].forEach(x => s. ...
- NAT穿透的详细讲解及分析
原文地址:http://bbs.pediy.com/thread-131961.htm 一.什么是NAT?为什么要使用NAT?NAT是将私有地址转换为合法IP地址的技术,通俗的讲就是将内网与内网通信时 ...
- 「题解」「POJ1322」Chocolate
目录 题目 原题目 简易题意 思路分析 代码 练习题 题目 原题目 点这里 简易题意 包裹里有无限个分布均匀且刚好 \(c\) 种颜色的巧克力,现在要依次拿 \(n\) 个出来放到桌子上.每次如果桌子 ...
- HDU3173 Dominos
单向并查集,问至少给几个点可以遍历全图,连通块数量n,入度为0的点的数量m,取max(n,m)~ #include<cstdio> #include<algorithm> #i ...
- Possible overdraw: Root element paints background @drawable/happy with a theme that also paints a background (inferred theme is @style/AppTheme)
安卓界面插入背景图片,当图片内存太大时,界面在切换时会加载失败,这是什么原因呢?这是设置android:background属性时发出的warning: Possible overdraw: Root ...
- spring boot 动态注入bean
方法一 SpringContextUtil public class SpringContextUtil { private static ApplicationContext application ...
- 【转】Node.js到底是用来做什么的
Node.js的到底是用来做什么的 在阐述之前我想放一个链接,这是国外的一个大神,对于node.js非常好的一篇介绍的文章,英文比较好的朋友可以直接去阅读,本文也很大程度上参考了这篇文章,也同时感谢知 ...
- string和 new string的区别
栈区 存 引用和基本类型,不能存对象,而堆区存对象.==是比较地址,equals()比较对象内容. (1) String str1 = "abcd"的实现过程:首先栈区创建 ...
- 4 CSS导航栏&下拉菜单&属性选择器&属性和值选择器
CSS导航栏 熟练使用导航栏,对于任何网站都非常重要 使用CSS你可以转换成好看的导航栏而不是枯燥的HTML菜单 垂直导航栏: <!DOCTYPE html> <html> & ...