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

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

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

2019-11-14 13:08:21
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

1 Vector容器簡(jiǎn)介

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

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

vector尾部添加或移除元素非常快速。但是在中部或頭部插入元素或移除元素比較費(fèi)時(shí)

2 vector對(duì)象的默認(rèn)構(gòu)造

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

vector<T> vecT;

 

vector<int> vecInt;         //一個(gè)存放int的vector容器。

vector<float> vecFloat;      //一個(gè)存放float的vector容器。

vector<string> vecString;    //一個(gè)存放string的vector容器。

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

Class CA{};

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

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

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

理論知識(shí)

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

2 vector(n,elem);   //構(gòu)造函數(shù)將n個(gè)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); //此代碼運(yùn)行后,容器vecIntB就存放3個(gè)元素,每個(gè)元素的值是9。

 

vector<int> vecIntD(vecIntA);

 

4 vector的賦值

理論知識(shí)

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

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

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

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的大小

理論知識(shí)

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

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

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

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

 

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

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

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

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

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

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

 

6vector末尾的添加移除操作  

vector<int> vecInt;

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

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

vecInt.push_back(5);  

vecInt.push_back(7);

vecInt.push_back(9);

vecInt.pop_back();    

vecInt.pop_back();

//{5 ,7 ,9}  

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

理論知識(shí)

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

vec[idx];   //返回索引idx所指的數(shù)據(jù),越界時(shí),運(yùn)行直接報(bào)錯(cuò)

 

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}

測(cè)試代碼

#include <iostream>using namespace std;#include "vector"void main1(){	vector<int> v1;//構(gòu)造一個(gè)容器v1	cout << "v1 before length:" << endl;	cout << v1.size() << endl;//得到容器v1的長(zhǎng)度	v1.push_back(1);//將數(shù)據(jù)加入到容器中	v1.push_back(2);	v1.push_back(3);	cout << "v1 after length:" << endl;	cout << v1.size() << endl;//測(cè)量加入數(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的長(zhǎng)度}int main(){	main1();	return 0;}測(cè)試結(jié)果:


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 安国市| 尚义县| 沂水县| 阿拉善左旗| 荆州市| 佛教| 弥渡县| 邳州市| 六枝特区| 桃源县| 江安县| 平南县| 邵阳县| 葵青区| 寿阳县| 康马县| 南宁市| 涿鹿县| 云霄县| 涟水县| 彩票| 郎溪县| 宿松县| 顺昌县| 甘孜县| 禄劝| 金沙县| 郧西县| 禄丰县| 远安县| 丹棱县| 民丰县| 凌源市| 房山区| 海丰县| 丽水市| 仁寿县| 灵山县| 永德县| 保定市| 江达县|