国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

C++之vector容器初學(xué)

2019-11-14 12:34:36
字體:
供稿:網(wǎng)友

1 Vector容器簡介

2 vector是將元素置于一個動態(tài)數(shù)組中加以管理的容器。

2 vector可以隨機存取元素(支持索引值直接存取, 用[]操作符或at()方法,這個等下會詳講)。

vector尾部添加或移除元素非常快速。但是在中部或頭部插入元素或移除元素比較費時

2 vector對象的默認構(gòu)造

vector采用模板類實現(xiàn),vector對象的默認構(gòu)造形式

vector<T> vecT;

 

vector<int> vecInt;         //一個存放int的vector容器。

vector<float> vecFloat;      //一個存放float的vector容器。

vector<string> vecString;    //一個存放string的vector容器。

...     //尖括號內(nèi)還可以設(shè)置指針類型或自定義類型。

Class CA{};

vector<CA*> vecpCA;    //用于存放CA對象的指針的vector容器。

vector<CA> vecCA;      //用于存放CA對象的vector容器。由于容器元素的存放是按值復(fù)制的方式進行的,所以此時CA必須提供CA的拷貝構(gòu)造函數(shù),以保證CA對象間拷貝正常。

3 vector對象的帶參數(shù)構(gòu)造

理論知識

2 vector(beg,end);    //構(gòu)造函數(shù)將[beg, end)區(qū)間中的元素拷貝給本身。注意該區(qū)間是左閉右開的區(qū)間。

2 vector(n,elem);   //構(gòu)造函數(shù)將n個elem拷貝給本身。

2 vector(const vector &vec);  //拷貝構(gòu)造函數(shù)

 

int  iArray[] = {0,1,2,3,4};

vector<int>  vecIntA( iArray,  iArray+5 );

 

vector<int> vecIntB (  vecIntA.begin() , vecIntA.end()  );   //用構(gòu)造函數(shù)初始化容器vecIntB

vector<int> vecIntB (  vecIntA.begin() , vecIntA.begin()+3  );  

vector<int> vecIntC(3,9); //此代碼運行后,容器vecIntB就存放3個元素,每個元素的值是9。

 

vector<int> vecIntD(vecIntA);

 

4 vector的賦值

理論知識

2 vector.assign(beg,end);    //將[beg, end)區(qū)間中的數(shù)據(jù)拷貝賦值給本身。注意該區(qū)間是左閉右開的區(qū)間。

2 vector.assign(n,elem);  //將n個elem拷貝賦值給本身。

2 vector& Operator=(const vector  &vec); //重載等號操作符

2 vector.swap(vec);  // 將vec與本身的元素互換。

 

vector<int> vecIntA, vecIntB, vecIntC, vecIntD;

int  iArray[] = {0,1,2,3,4};

vecIntA.assign(iArray,iArray+5);

 

vecIntB.assign( vecIntA.begin(),  vecIntA.end() );    //用其它容器的迭代器作參數(shù)。

 

vecIntC.assign(3,9);

 

vector<int> vecIntD;

vecIntD = vecIntA;

 

vecIntA.swap(vecIntD);

5 vector的大小

理論知識

2 vector.size();    //返回容器中元素的個數(shù)

2 vector.empty();    //判斷容器是否為空

2 vector.resize(num);   //重新指定容器的長度為num,若容器變長,則以默認值填充新位置。如果容器變短,則末尾超出容器長度的元素被刪除。

2 vector.resize(num, elem);  //重新指定容器的長度為num,若容器變長,則以elem值填充新位置。如果容器變短,則末尾超出容器長度的元素被刪除。

 

例如   vecInt是vector<int>  聲明的容器,現(xiàn)已包含1,2,3元素。

int iSize = vecInt.size(); //iSize == 3;

bool bEmpty = vecInt.empty(); // bEmpty == false;

執(zhí)行vecInt.resize(5);  //此時里面包含1,2,3,0,0元素。

再執(zhí)行vecInt.resize(8,3);  //此時里面包含1,2,3,0,0,3,3,3元素。

再執(zhí)行vecInt.resize(2);  //此時里面包含1,2元素。

 

6vector末尾的添加移除操作  

vector<int> vecInt;

vecInt.push_back(1);  //在容器尾部加入一個元素

vecInt.push_back(3);  //移除容器中最后一個元素

vecInt.push_back(5);  

vecInt.push_back(7);

vecInt.push_back(9);

vecInt.pop_back();    

vecInt.pop_back();

//{5 ,7 ,9}  

7vector的數(shù)據(jù)存取

理論知識

vec.at(idx);   //返回索引idx所指的數(shù)據(jù),如果idx越界,拋出out_of_range異常。

vec[idx];   //返回索引idx所指的數(shù)據(jù),越界時,運行直接報錯

 

vector<int> vecInt;    //假設(shè)包含1 ,3 ,5 ,7 ,9

vecInt.at(2) == vecInt[2] ; //5

vecInt.at(2) = 8;  或  vecInt[2] = 8;

vecInt 就包含 1, 3, 8, 7, 9值

 

int iF = vector.front(); //iF==1

int iB = vector.back(); //iB==9

vector.front() = 11; //vecInt包含{11,3,8,7,9}

vector.back() = 19; //vecInt包含{11,3,8,7,19}

測試代碼

#include <iostream>using namespace std;#include "vector"void main1(){	vector<int> v1;//構(gòu)造一個容器v1	cout << "v1 before length:" << endl;	cout << v1.size() << endl;//得到容器v1的長度	v1.push_back(1);//將數(shù)據(jù)加入到容器中	v1.push_back(2);	v1.push_back(3);	cout << "v1 after length:" << endl;	cout << v1.size() << endl;//測量加入數(shù)據(jù)后的容器大小	cout << "頭部元素" << v1.front() << endl;	v1.front() = 11;//修改頭部元素	v1.back() = 55;//修改尾部元素	while (v1.size() > 1)	{		cout << "尾部元素為:" << v1.back() << endl;		v1.pop_back();//刪除尾部元素	}	cout << v1.size() << endl;//得到容器v1的長度}int main(){	main1();	return 0;}測試結(jié)果:


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 望江县| 孟州市| 梨树县| 洛宁县| 科技| 收藏| 商城县| 奉新县| 晋江市| 习水县| 金昌市| 花莲县| 方正县| 凉城县| 洪泽县| 东阳市| 肇源县| 大同市| 葵青区| 吴旗县| 项城市| 德江县| 沙洋县| 宜宾县| 运城市| 凌云县| 赤城县| 长治县| 涿鹿县| 禄劝| 洛阳市| 孟村| 上思县| 汶川县| 石阡县| 台东市| 来安县| 遂溪县| 洛扎县| 武清区| 枣庄市|