vector使用小结
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使用小结的更多相关文章
- c++第十四天
<c++ primer, 5E> 第91页到第94页,笔记: 1.vector支持的操作. v.empty().v.size().v.push_back(t).v[n] 2.试图通过下标访 ...
- STL中vector小结
()使用vector之前必须包含头文件<vector>:#include<vector> ()namespace std{ template <class T, clas ...
- C++中标准容器Vector,元素操作.insert()小结
insert() 函数有以下三种用法: iterator insert( iterator loc, const TYPE &val ); //在指定位置loc前插入值为val的元素,返回指 ...
- vector的用法小结(待补全
1.vector的好处 支!持!删!除! 节!省!内!存! 2.一点基础的小操作 ①插入操作:v.push_back(x) 在尾部插入元素x: ②删除操作 : v.erase(x)删除地址为x的元素 ...
- ?:,reverse,vector的基本小结
#include <cstdio> //此代码为网上所复制 #include <iostream> #include <string> #include <s ...
- HTML最新标准HTML5小结
写在前面 HTML5出来已经很久了,然而由于本人不是专业搞前端的,只知道有这个东西,具体概念有点模糊(其实就是一系列标准规范啦):因此去年(2015.11.09),专门对HTML5做了个简单的小结,今 ...
- 学习RaphaelJS矢量图形包--Learning Raphael JS Vector Graphics中文翻译(一)
(原文地址:http://www.cnblogs.com/idealer3d/p/LearningRaphaelJSVectorGraphics.html) 前面3篇博文里面,我们讲解了一本叫做< ...
- C++ typedef用法小结 (※不能不看※)
C++ typedef用法小结 (※不能不看※) 第一.四个用途 用途一: 定义一种类型的别名,而不只是简单的宏替换.可以用作同时声明指针型的多个对象.比如:char* pa, pb; // 这多数不 ...
- 跟我一起学STL(2)——vector容器详解
一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...
随机推荐
- Java - 数组解析
java提高篇(十八)-----数组之一:认识JAVA数组 一.什么是数组 数组?什么是数组?在我印象中的数组是应该这样的:通过new关键字创建并组装他们,通过使用整形索引值访问它的元素,并且它的尺寸 ...
- python学习之老男孩python全栈第九期_day007作业
一.关系运算 有如下两个集合,pythons是报名python课程的学员名字集合,linuxs是报名linux课程的学员名字集合pythons={'alex','egon','yuanhao','wu ...
- codevs1735 方程的解数(meet in the middle)
题意 题目链接 Sol 把前一半放在左边,后一半放在右边 meet in the middle一波 统计答案的时候开始想的是hash,然而MLE了两个点 实际上只要排序之后双指针扫一遍就行了 #inc ...
- CentOS7安装mongodb
1.下载mongodb的*.tar.gz安装包 2.移到centos7中并解压 tar -xzvf mongodb.tar.gz 3.配置环境变量 vim /etc/profile 添加如下内容: # ...
- Eclipse中JSP生成的类文件存放在哪
Jsp页面看上去和HTML相似,但它实际上是作为Servlet运行的. 当JSP页面第一次被访问时,web容器解析jsp文件并将其转化为相应的java文件,该文件声明了一个servlet类,该类称为页 ...
- ActiveReports 报表应用教程 (11)---交互式报表之文档目录
通过文档目录,用户可以非常清晰的查看报表数据结构,并能方便地跳转到指定的章节,最终还可以将报表导出为PDF等格式的文件.本文以2012年各月产品销售分类汇总报表为例,演示如何在葡萄城ActiveRep ...
- Git删除文件
Git基础 Git有三大区(工作区.暂存区.版本库),文件有三个状态(untracked.unstaged.uncommited). (1)打开项目文件夹,除了隐藏的.git文件夹,其他项目文件位于的 ...
- __细看InnoDB数据落盘 图解 MYSQL
http://hatemysql.com/?p=503 1. 概述 前面很多大侠都分享过MySQL的InnoDB存储引擎将数据刷新的各种情况.我们这篇文章从InnoDB往下,看看数据从InnoDB的 ...
- Linux 配置 hosts
1. hosts 是什么 维基百科对 hosts 的介绍如下: hosts文件(域名解析文件)是一个用于储存计算机网络中各节点信息的计算机文件. 这个文件负责将主机名称映射到相应的IP地址. host ...
- 第二次作业 单例模式的SessionFactory以及线程安全的session
单例模式的SessionFactory 在这个工具类Hibernate.java中写一个通过静态代码块生成唯一的SessionFactory,通过一个方法返回一个SessionFactory impo ...