STL序列容器之vector
一,vector容器简介
1.vector容器的原理
vector是将元素置于一个动态数组中加以管理的容器。
2.vector容器的特点
vector容器可以随机存取元素,支持索引存取(即用数组下标的方式存取)。vector容器在尾部插入和删除数据比较快,但是在中部或者头部插入或者删除元素比较费时。
3.vector容器的使用
vector容器对应得头文件:# include<vector>
二,vector容器的构造函数
1.vector的无参构造函数
// 定义一个存放int类型的向量容器
vector<int> v1;
// 定义存放一个double类型的向量容器
vector<double> v2;
// 定义一个存放string类型的向量容器
vector<string> v3;
// 定义一个存放自定义类型的向量容器,该类型必须提供拷贝构造函数,因为容器的存放是按值复制的方式
vector<Student> v4;
2.vector的有参构造函数
// 使用数组初始化vector
int array[] = { ,,,,,,,, };
vector<int> v1(array, array + );
// 使用vector初始化vector
vector<int> v2(v1.begin(), v1.begin() + );
// 使用n个相同的元素初始化vector
vector<char> v3(, 'A');
3.vector的拷贝构造函数
// 使用n个相同的元素初始化vector
vector<char> v1(, 'A');
// 拷贝构造函数
vector<char> v2 = v1;
4.vector的析构函数
vector的析构函数和用来释放容器中元素所占用的内存。
三,操作符重载函数
1.赋值操作符
// 定义向量v1
vector<char> v1(, 'A');
// 定义向量v2
vector<char> v2;
// 赋值操作符重载
v2 = v1;
2.数组下标操作符
// 创建vector容器
vector<char> v;
// 添加元素到vector中
v.push_back('A');
v.push_back('B');
v.push_back('C');
v.push_back('D');
// 获取第二个元素
char c2 = v[];
// 修改第二个元素
v[] = 'X';
四,成员函数
1.vector的尾部添加和尾部删除操作
// vector的尾部添加元素
vector<char> v1;
v1.push_back('A');
v1.push_back('B');
v1.push_back('C');
v1.push_back('D');
// vector的尾部删除元素
v1.pop_back();
v1.pop_back();
2.vector获取头部和尾部元素
// 创建vector容器
vector<char> v1;
// 往vector插入元素
v1.push_back('A');
v1.push_back('B');
v1.push_back('C');
v1.push_back('D');
// 获取vector的头元素和尾部元素
char first = v1.front();
char last = v1.back();
3.vector的长度
// 定义vector容器
vector<int> v1(,);
// 获取vector的长度
int v1_size = v1.size();
4.vector是否为空及清空元素操作
// 创建vector容器
vector<int> v1(,);
// 判断vector容器是否为空
bool isEmpty = v2.empty();
// vector容器的元素清空
v2.clear();
5.vector元素的获取和修改
// 创建vector容器
vector<char> v;
// 添加元素到vector中
v.push_back('A');
v.push_back('B');
v.push_back('C');
v.push_back('D');
// 获取第二个元素
char c2 = v[];
// 获取第三个元素
char c3 = v.at();
// 修改第二个元素
v[] = 'X';
6.vector的遍历
// 创建vector容器
vector<int> v1(,);
// 增强for遍历
for (int tmp : v1)
{
cout << tmp << " ";
}
cout << endl;
// 迭代器正向遍历
for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++)
{
*it += ;
cout << *it << " ";
}
cout << endl;
// 迭代器逆向遍历
for (vector<int>::reverse_iterator it = v1.rbegin(); it != v1.rend(); it++)
{
cout << *it << " ";
}
cout << endl;
7.vector的插入
// 创建vector容器
vector<char> v(, 'A');
// 在vector容器的第二个位置插入字符'X'
v.insert(v.begin() + , 'X');
// 在vector容器的最后位置插入5个'B'
v.insert(v.end(), , 'B');
8.vector的删除
// 创建vector容器
vector<char> v;
// 存入数据
v.push_back('A');
v.push_back('B');
v.push_back('C');
v.push_back('D');
v.push_back('E');
// 删除第2个元素
v.erase(v.begin() + );
// 删除最后两个元素
v.erase(v.end() - , v.end());
9.vector的遍历删除
# include<iostream>
# include<vector>
# include<deque> using namespace std; int main()
{
// 定义容器
vector<int> v;
// 添加数据
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
// 这里注意不需要++it
for (vector<int>::iterator it = v.begin(); it != v.end();)
{
// 删除偶数
if (*it % == )
{
// erase删除该元素后返回下一个元素的迭代器
it = v.erase(it);
}
else {
it++;
}
}
// 遍历
for (int tmp : v)
{
cout << tmp << " ";
}
cout << endl; return ;
}
五,vector容器添加自定义数据类型
1.定义老师类
#pragma once
# include<iostream>
using namespace std;
/* 定义老师类 */
class Teacher
{
private:
char * name;
int age;
public:
Teacher();
Teacher(char * name, int age);
/* 如果往容器中存入数据,必须定义拷贝构造函数 */
Teacher(const Teacher& teacher);
~Teacher();
public:
friend ostream& operator<<(ostream& out, Teacher& teacher);
};
2.老师类的实现
# define _CRT_SECURE_NO_WARNINGS
# include<iostream>
# include"Teacher.h"
using namespace std;
/* 无参构造 */
Teacher::Teacher()
{
this->name = NULL;
this->age = ;
}
/* 有参构造 */
Teacher::Teacher(char * name, int age)
{
this->name = new char[strlen(name)+];
strcpy(this->name, name);
this->age = age;
}
/* 拷贝构造函数 */
Teacher::Teacher(const Teacher& teacher)
{
this->name = new char[strlen(teacher.name)+];
strcpy(this->name, teacher.name);
this->age = teacher.age;
}
/* 析构函数 */
Teacher::~Teacher()
{
if (this->name != NULL)
{
delete [] this->name;
this->name = NULL;
this->age = ;
}
}
/* 友元函数:重载左移操作符 */
ostream& operator<<(ostream& out, Teacher& teacher)
{
cout << teacher.name << " = " << teacher.age;
return out;
}
3.向量容器存入老师对象
# include<iostream>
# include<vector>
# include"Teacher.h"
using namespace std; int main()
{
// 定义容器
vector<Teacher> v;
// 定义5个老师对象
Teacher t1("刘备", );
Teacher t2("关羽", );
Teacher t3("张飞", );
Teacher t4("赵云", );
Teacher t5("马超", );
// 存入向量容器
v.push_back(t1);
v.push_back(t2);
v.push_back(t3);
v.push_back(t4);
v.push_back(t5);
// 遍历
for (Teacher t : v)
{
cout << t << endl;
} return ;
}
STL序列容器之vector的更多相关文章
- C++STL模板库序列容器之vector
目录 STL之Vecter 一丶STL简介 二丶Vector用法 1.vector容器的使用 2.vector迭代器. 3.vector中的方法. 三丶常用算法 1.常见算法中的算法方法. 2.sor ...
- C++序列容器之 vector常见用法总结
一.关于vector 本文默认读者具有一定的c++基础,故大致叙述,但保证代码正确. vector是一个动态的序列容器,相当于一个size可变的数组. 相比于数组,vector会消耗更多的内存以有效的 ...
- STL序列容器之deque
一,deque的基础知识 1.deque的基础 deque是“double-ended-queue”的缩写,意思是双端队列,其和vector的区别在于vector是单端的. deque在头部和尾部插入 ...
- [知识点]C++中STL容器之vector
零.STL目录 1.容器之map 2.容器之vector 3.容器之set 一.前言 关于STL和STL容器的概念参见STL系列第一篇——map(见上).今天介绍第二个成员——vector. 二.用途 ...
- C++ 序列式容器之vector
什么是容器 容器,顾名思义,是用来容放东西的场所.C++容器容放某种数据结构,以利于对数据的搜寻或排序或其他特殊目的.众所周知,常用的数据结构不外乎:数组array, 链表list, 树tree ...
- STL容器之vector
[1]模板类vector 模板类vector可理解为广义数组.广义数组,即与类型无关的数组,具有与数组相同的所有操作. 那么,你或许要问:既然C++语言本身已提供了一个序列式容器array,为什么还要 ...
- C++STL模板库序列容器之List容器
目录 一丶List容器的存储结构 二丶丶STL中list容器的使用. 一丶List容器的存储结构 list容器底层是链表结构来维护的.跟vector不一样. vector是数组维护的.拥有连续内存.所 ...
- C++STL模板库序列容器之deque
目录 一丶队列容器deque简介 二丶使用代码演示 一丶队列容器deque简介 deque底层跟vector一样,都是数组维护.不同的是可以操作头部. 二丶使用代码演示 #define _CRT_SE ...
- C++ STL 常用容器之 stack
C++ STL Container--Stack 栈是一种先进后出(LIFO)的数据结构,限制只能在一端完成插入和删除操作,这一端叫做栈顶(top),另一端即为栈底(bottom).C++ STL(S ...
随机推荐
- jedis连接sentinel示例程序
1.添加依赖pom.xml <dependency> <groupId>redis.clients</groupId> <artifactId>jedi ...
- 从零开始使用git第三篇:git撤销操作、分支操作和常见冲突
从零开始使用git 第三篇:git撤销操作.分支操作和常见冲突 第一篇:从零开始使用git第一篇:下载安装配置 第二篇:从零开始使用git第二篇:git实践操作 第三篇:从零开始使用git第三篇:gi ...
- Spring 定时器 No qualifying bean of type [org.springframework.scheduling.TaskScheduler] is defined(转)
最近项目里面,用了spring的定时任务,一直以来,项目运行的不错.定时器也能正常使用.可是,今天启动项目测试的时候,盯着启动Log看了一阵子,突然间发现,启动的Log中居然有一个异常,虽然一闪而过, ...
- js cookie介绍和实例(用于自动登录,记住用户名等)
js cookie介绍和实例(用于自动登录,记住用户名等) 一.总结 1.cookie在客户端:因为js是最初是用来在客户端和服务器端进行通信使用的,所以客户端比如js可以操作cookie正常 2.c ...
- 黑马day18 jquery高级特性&Ajax的load方法
介绍jquery中的load方法: (1).前面没有jquery.修饰,能够判断出他是一个普通的非全局函数(也就是说是一个局部函数):$.,$().,jquery.等修饰的就是全局函数.没有这些修饰的 ...
- iOS开发Quartz2D之 七:雪花效果
#import "VCView.h" @implementation VCView -(void)awakeFromNib { //[NSTimer scheduledTimerW ...
- Java 学习(22):Java MySQL 连接
Java MySQL 连接 本章节我们为大家介绍 Java 如何使用 使用 JDBC 连接 MySQL 数据库. Java 连接 MySQL 需要驱动包,最新版下载地址为:http://dev.mys ...
- JavaScript实现form表单的多文件上传
form表单的多文件上传,具体内容如下 formData对象可以使用一系列的键值对来模拟一个完整的表单,然后使用Ajax来发送这个表单 使用<form>表单初始化FormData对象的方式 ...
- ijkplayer阅读笔记02-创建音视频读取,解码,播放线程
本节主要介绍音视频读取和解码线程的创建及启动,代码流程例如以下: IjkMediaPlayer_prepareAsync{ ijkmp_prepare_async_l{ ijkmp_change_st ...
- toLocaleDateString()
在处理时间问题的时候,遇到了一个bug,关于toLocaleDateString()在不同浏览器下的解析结果. 代码如下 浏览器解析结果如下 可以看到谷歌,火狐等浏览器的输出结果是这种格式的 *201 ...