上一节我们具体了解了vector容器的迭代器及其使用方法,本节主要详细介绍各种访问vector内元素的方法,vector容器的访问方式和array非常像,可以跳转至《如何访问array容器内的元素?》将array和vector的访问方式类比起来学习,但是有一点需要牢牢记住,vector可不能通过get()函数模板进行访问!。这里也会详细讲解vector内元素的访问方式,因为学习既需要触类旁通,也需要重复训练。以下是几种访问vector内元素的方法:
和普通数组、array一样,vector重载了'[]'运算符,我们可以通过'[]'访问vector内的元素:
#include<bits/stdc++.h>
/* 如何访问vector容器内元素 */
using namespace std;
/*方法1:由于'[]'运算符重载实现下标访问*/
void test()
{
vector<int> v{1,2,3,4,5};
for(int i=0;i<5;++i)
{
cout << v[i] << " ";
}
cout << '\n';
}
int main(){
test();
return 0;
}vector容器提供了at()这个成员函数进行元素访问,由于at函数内的参数是元素下标,范围是[0,vector.size()-1],所以这里千万注意不要访问越界!
cout << v.at(i) << " "; //通过at()成员函数进行元素访问 参数是元素下标
众所周知'[]'(因为它没有进行索引检查)访问速度非常快,既然可以通过'[]'访问元素了那么为什么会出现at这个成员函数呢?原因很简单,通过'[]'访问,如果数组越界,会造成程序崩溃,而你不知道是哪里问题,需要逐一排查。而我们的at()会提示你错误原因,比如此时我访问一个arr里面没有的元素:
cout << v.at(100)<<'\n';
会出现这么一个报错:
terminate called after throwing an instance of 'std::out_of_range'
what(): vector::_M_range_check: __n (which is 100) >= this->size() (which is 5)
它的意思是只有5个元素,而你却向访问第100个元素,简直是痴心妄想。
c++提供了get<n>这个函数模板进行元素访问,访问且只能访问编译时确定大小的容器,由于vector是动态数组,所以这里不能使用vector进行元素访问!(划重点)
既然学STL,那就记得迭代器吧,想起迭代器,你就要有“迭代器使用类似指针”这个印象,指针?没想到吧,vector容器有一个成员函数data()维护指向首元素的指针,那我们分别通过迭代器和指针访问第5个元素:
#include<bits/stdc++.h>
/* 如何访问vector容器内元素 */
using namespace std;
/*c++中get()函数模板进行元素访问*/
void test()
{
vector<int> v{1,2,3,4,5};
/*迭代器访问第5个元素*/
vector<int>::iterator it = v.begin() ;
for(int i=0;i<4;++i)it++;
cout << *it << '\n';
/*data()指针访问*/
int * p = v.data() ;
for(int i=0;i<4;++i)++p;
cout <<*p<< '\n';
p=nullptr;
}
int main(){
test();
return 0;
}当然,如果只需要访问首尾位元素,back()和front()足矣:
cout << "首位元素是" << v.front() << '\n'; cout << "尾位元素是" << v.back() << '\n';
总结:共计4种方式访问vector容器内的元素,分别是'[]'、迭代器、指针和at()成员函数,单独访问首尾元素,back()和front()需要铭记于心。
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程