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

首頁 > 學院 > 開發設計 > 正文

C++之vector容器初學

2019-11-14 12:35:03
字體:
來源:轉載
供稿:網友

1 Vector容器簡介

2 vector是將元素置于一個動態數組中加以管理的容器。

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

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

2 vector對象的默認構造

vector采用模板類實現,vector對象的默認構造形式

vector<T> vecT;

 

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

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

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

...     //尖括號內還可以設置指針類型或自定義類型。

Class CA{};

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

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

3 vector對象的帶參數構造

理論知識

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

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

2 vector(const vector &vec);  //拷貝構造函數

 

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

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

 

vector<int> vecIntB (  vecIntA.begin() , vecIntA.end()  );   //用構造函數初始化容器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)區間中的數據拷貝賦值給本身。注意該區間是左閉右開的區間。

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() );    //用其它容器的迭代器作參數。

 

vecIntC.assign(3,9);

 

vector<int> vecIntD;

vecIntD = vecIntA;

 

vecIntA.swap(vecIntD);

5 vector的大小

理論知識

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

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

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

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

 

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

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

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

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

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

再執行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的數據存取

理論知識

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

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

 

vector<int> vecInt;    //假設包含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;//構造一個容器v1	cout << "v1 before length:" << endl;	cout << v1.size() << endl;//得到容器v1的長度	v1.push_back(1);//將數據加入到容器中	v1.push_back(2);	v1.push_back(3);	cout << "v1 after length:" << endl;	cout << v1.size() << endl;//測量加入數據后的容器大小	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;}測試結果:


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 台湾省| 闽清县| 丽江市| 孟津县| 卢湾区| 珲春市| 宜兰县| 加查县| 黄石市| 尉犁县| 望城县| 沾益县| 灯塔市| 思南县| 疏勒县| 铜梁县| 滦平县| 靖州| 峨眉山市| 罗田县| 郑州市| 高台县| 临洮县| 新宁县| 罗甸县| 黑河市| 清远市| 阿克苏市| 滕州市| 浦县| 河南省| 绵阳市| 汨罗市| 天门市| 珠海市| 崇明县| 阆中市| 宣武区| 四川省| 修水县| 隆昌县|