Vector是一個(gè)容器。是一個(gè)模板類,允許我們重復(fù)利用已有的實(shí)現(xiàn)構(gòu)造自己的特定類型下的數(shù)據(jù)結(jié)構(gòu)。vector的參數(shù)允許我們制定容器匯總的元素的數(shù)據(jù)類型。
一、基本操作:
1)頭文件聲明:#include<vector>;
2)創(chuàng)建vector對象:vector<int> vec;
3)尾部插入數(shù)字:vec.push_back(a);
4)使用下標(biāo)訪問元素,cout<<vec[1]<<endl;下標(biāo)是從0開始的;
5)使用迭代器訪問元素:
vector<int>::iterator it;
for(it=vec.begin();it!=vec.end();it++)
cout<<*it<<endl;
6)插入元素:vec.insert(vec.begin()+i,a);在第i+1個(gè)元素前面插入a;
7)刪除元素:vec.earse(vec.begin()+2);刪除第三個(gè)元素
vec.earse(vec.begin()+i,vec.end()+j);刪除區(qū)間[i,j-1]之間的元素,區(qū)間從0開始。左閉右開;
8)向量大小:vec.size();
9)清空:vec.clear();
二、高級操作:
1)反轉(zhuǎn):需要頭文件#include<algorithm>
reverse(vec.begin(),vec.end());將元素反轉(zhuǎn),(在vector中,如果一個(gè)函數(shù)需要兩個(gè)迭代器,一般后一個(gè)都不包含);
2)sort排序:需要頭文件#include<algorithm>
sort(vec.begin().vec.end());(默認(rèn)按照升序排序,即從小到大);
可以重寫排序函數(shù),實(shí)現(xiàn)降序,如下:
bool Comp(const int &a,const int &b)
{
return a>b;
}
調(diào)用時(shí),sort(vec.begin(),vec.end(),Comp),這樣就能夠降序排序。
C++中,使用vector<vector<double>>來表示矩陣,主要用在OpenCV中。
vector<vector<double>>與Mat數(shù)據(jù)類型可以相互轉(zhuǎn)換。
const vector<int>::iterator中,const是修飾的迭代器,也就是是個(gè)常迭代器,相當(dāng)于C語言中int *const p,指針值不能變,地址下的值能變。比如:
const vector<int>::iterator iter = i.begin; iter++;//不可以vector<int>::const_iterator iter相當(dāng)于C語言中的int const *p,就是地址下的實(shí)際值不能改變。比如:vector<int>::const_iterator iter = i.begin(); *iter = 10;//不能迭代器只是一個(gè)對象,編譯器無法分辨是常指針還是指向常量的指針。使用它,通過迭代器對所指向的內(nèi)容進(jìn)行修改是非法的。
新聞熱點(diǎn)
疑難解答
圖片精選