目录
一.Vector的简介
在C++语言中,有了标准模板库STL的出现,大大的提升了编程的效率。而今天我要介绍的是其中的Vector
vector是C++标准模板库中的部分内容,中文偶尔译作“容器”,但并不准确。它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。——引自百度百科
vector是一个动态数组类,而且可以实现模板编程,属于是一个模板类。使用它要包含头文件和使用标准命名空间。
#include<iostream>
#include<vector>
using namespace std;
二.Vector的使用
1.创建vector
vector以类模板vector<T>的形式创建(T要储存元素的类型),可以实现多种类型的推演。
std::vector<int> name//名字为name,元素为int的vector数组
std::vector<double> name//名字为name,元素为double的vector数组
下面我们以整型变量为例,介绍vector的成员函数。
2.vector的初始化
任何变量创建后第一步一般都是进行初始化,vector也不例外,下面介绍几种常用的初始化方式。
2.1.花括号直接初始化
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> v{1,2,3,4,5};
for (auto& r : v)
{
cout << r << " ";
}
cout << endl;
int a[5] = { 1,2,3,4,5 };
for (auto& r : a)
{
cout << r << " ";
}
return 0;
}
结果都是1 2 3 4 5。
2.2.小括号初始化
2.2.1一个参数的情况
vector<int> v(5);
for (auto& r : v)
{
cout << r << " ";
}
结果是0 0 0 0 0,一个参数会初始化元素个数并把他们的默认值都改为0。
2.2.2.两个参数的情况
vector<int> v(5,1);
for (auto& r : v)
{
cout << r << " ";
}
return 0;
结果是1 1 1 1 1,两个参数会初始化元素个数并把他们的值都该为第二个参数。值得注意的是,这两个参数都可以是变量,都可以用变量表示。
2.3.用另一个vector初始化
既然是类,那么肯定也有类的拷贝构造函数
vector<int> v1(5, 1);
vector<int> v2(v1);
这样v2的值也是5个1。
三.vector的元素访问
1.at
vector<int> v1{ 1,2,3,4,5 };
cout << v1.at(4);
结果是5.at可也访问指定元素,同时进行越界检查。
2.operator[]
[]操作符进行了重载,也可向访问数组那样对vector进行访问。
vector<int> v1{ 1,2,3,4,5 };
cout << v1[4];
3.迭代器访问
迭代器其实就像指针一样
vector<int> v1{ 1,2,3,4,5 };
for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++)
{
cout << *it << " ";
}
begin返回初始位置的迭代器,end返回末位置的迭代器循环遍历整的vector。
四.vector的常用函数
1.empty()
该函数检查容器是否为空,如果为空返回true,否则返回false。
vector<int> v1{ 1,2,3,4,5 };
if (v1.empty() == false)
{
cout << "no empty" << endl;
}
else
{
cout << "empty" << endl;
}
2.size()
返回容器的元素数,在使用下标访问的时候作为结束条件。
vector<int> v1{ 1,2,3,4,5 };
for (int i = 0; i < v1.size(); i++)
{
cout << v1[i] << " ";
}
3.clear()
清空容器所有元素,将size返回值置为0。
vector<int> v1{ 1,2,3,4,5 };
v1.clear();
cout << v1.size() << endl;
for (int i = 0; i < v1.size(); i++)
{
cout << v1[i] << " ";
}
4.push_back()
将元素添加至容器末尾。
vector<int> v1{ 1,2,3,4,5};
v1.push_back(6);
for (int i = 0; i < v1.size(); i++)
{
cout << v1[i] << " ";
}
5.pop_back()
删除末尾位置元素
vector<int> v1{ 1,2,3,4,5};
v1.pop_back();
for (int i = 0; i < v1.size(); i++)
{
cout << v1[i] << " ";
}
6.insert()
在容器中插入元素,该函数的重载形式有很多。我们介绍其中一部分。
#include <iostream>
#include <vector>
using namespace std;
void print_V(vector<int>& v)
{
for (int i = 0; i < v.size(); i++)
{
cout << v[i] << " ";
}
cout << endl;
}
int main()
{
vector<int> v{ 1,2 };
//第一种格式用法
v.insert(v.begin() + 1, 3);//{1,3,2}
print_V(v);
//第二种格式用法
v.insert(v.end(), 2, 5);//{1,3,2,5,5}
print_V(v);
//第三种格式用法
v.insert(v.end(), { 10,11 });//{1 3 2 5 5 10 11}
print_V(v);
return 0;
}
第一种用法是将首位置迭代器,要加元素值当作参数传入,在指定位置加入元素。
第二种用法是将末位置迭代器,要加元素个数,元素值。在是指定位置加入几个相同的值,当然第一个参数也可以换成首位置迭代器。
第三种是在指定位置之后加入一串数字。
标签:初始化,vector,cout,迭代,STL,元素,v1,Vector,使用 From: https://blog.csdn.net/2301_80190222/article/details/136764086