我作为一个计算机小白,经过自己的一系列学习,对于STL容器中的vector容器有了自己的一些见解
首先呢对于vector容器,网上或者书上的解释是一个动态的分配内存的容器,其实,我们可以把它和数组进行对比理解,首先,学习过最最基础的数组的同志们肯定了解数组的定义是怎么样的,我举个例子:
我们定义一个拥有十个内存空间的整型的数组:int a[10];
那么这就来了,这个定义的int型的数组,需要你提前分配好空间,然后进行输入,这个以及定义的数组,就是这10个空间的大小,你以及无法再给他扩展或者缩小了,所以我把它理解成是静态的内存。
并且这个数组当中,你只能最多输入10个int型的数据,如果超过十个就无法输入,这也就要求我们要提前知道,我们 要输入的数据具体是多少个,然后我们再来定义一个多大的空间。
然而,vector容器则可以理解为是一个动态分配空间的东西,不需要提前给它取一个多大的内存空间,你给他插入多少个数据,它在插入数据的那一刻,给你分配空间。
也就是说,即使我们不知道具体要输入多少个数据,不知道要分配多大的空间,用vector容器可以解决这个问题(当然,我说的是对于简单的算法题,不是那么多且庞杂的数据)。
那么该如何进行vector 容器的初始化定义呢?下面给大家演示一下,我平常的定义(只是我自己习惯的定义形式,又不对的地方请大家指正)
#include<iostream>
#include<ctype.h>
#include<cstring>
#include<algorithm>
#include <vector>
using namespace std;
int main()
{ int a;//创建一个整型变量,只开一个空间
vector<int> v; //STL 中的标准容器之一 :动态数组
for(int i=0;i<5;i++)
{ cin>>a; //在这里利用a[]开的空间,将每一个输入的值放进vector容器当中去
v.push_back(a);
} //push_back()是vector 容器提供的插入数据的方法
return 0;
}
当然,我上面写的是从键盘输入了五个整型的数据,如果不知道到底需要输入几个数据的话可以用while语句,判断条件可以是eof(我认为理论上可以),或者是输入的a!=某个值。
上面的利用一个数组,从键盘输入再放进容器的办法是我最近自己想出来的,本人刚接触计算机时间不久,如果哪里不对,或者理论错误,请各位前辈或者网友进行指正批评!