這篇文章主要介紹了C++怎么使用std::vector容器的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇C++怎么使用std::vector容器文章都會有所收獲,下面我們一起來看看吧。
創(chuàng)新互聯(lián)自成立以來,一直致力于為企業(yè)提供從網(wǎng)站策劃、網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、網(wǎng)站制作、電子商務(wù)、網(wǎng)站推廣、網(wǎng)站優(yōu)化到為企業(yè)提供個性化軟件開發(fā)等基于互聯(lián)網(wǎng)的全面整合營銷服務(wù)。公司擁有豐富的網(wǎng)站建設(shè)和互聯(lián)網(wǎng)應(yīng)用系統(tǒng)開發(fā)管理經(jīng)驗、成熟的應(yīng)用系統(tǒng)解決方案、優(yōu)秀的網(wǎng)站開發(fā)工程師團(tuán)隊及專業(yè)的網(wǎng)站設(shè)計師團(tuán)隊。
vector實質(zhì)是C++的一個類,與數(shù)組很相似,但是vector的優(yōu)勢是可以動態(tài)擴(kuò)展,不需要考慮其內(nèi)存大小。
定義:
向量(Vector)是一個封裝了動態(tài)大小數(shù)組的順序容器(Sequence Container)。跟任意其它類型容器一樣,它能夠存放各種類型的對象。可以簡單的認(rèn)為,向量是一個能夠存放任意類型的動態(tài)數(shù)組。
特性:
1.順序序列
順序容器中的元素按照嚴(yán)格的線性順序排序??梢酝ㄟ^元素在序列中的位置訪問對應(yīng)的元素。
2.動態(tài)數(shù)組
支持對序列中的任意元素進(jìn)行快速直接訪問,甚至可以通過指針?biāo)闶鲞M(jìn)行該操作。操供了在序列末尾相對快速地添加/刪
除元素的操作。
3.能夠感知內(nèi)存分配器的(Allocator-aware)
容器使用一個內(nèi)存分配器對象來動態(tài)地處理它的存儲需求。
vector
vector(data.begin(),data.end()); //將data的【begin(),end())區(qū)間中的元素拷貝給本身,注意是數(shù)學(xué)中的前閉后開 區(qū)間
vector(n,elem); //將n個elem元素拷貝給本身
vector(const vector &data); //拷貝構(gòu)造
#include#include using namespace std; void fun_print_vector(std::vector &data) { //std::vector ::iterator it; //可以用auto代替。 for(auto it_data = data.begin();it_data != data.end();it_data++){ std::cout << *it_data << " " << std::endl; } } void fun_vector() { vector data1; //默認(rèn)構(gòu)造 data1.push_back(1); data1.push_back(2); data1.push_back(3); fun_print_vector(data1); //打印:1 2 3 vector data2(data1.begin(),data1.end()); //通過區(qū)間進(jìn)行構(gòu)造 fun_print_vector(data2); //打?。? 2 3 vector data3(4,1);//4個1構(gòu)造 fun_print_vector(data3); //打?。? 1 1 1 vector data4(data3); //拷貝構(gòu)造 fun_print_vector(data4); //打?。? 1 1 1 }
vector& operator=(cost vector &data); //重載操作符
vector& assign(beg,end); //將[ beg,ed )區(qū)間中的數(shù)據(jù)拷貝賦值給本身
vector& assign(n,elem); //將n個elem拷貝賦值給本身
#include#include using namespace std; void fun_print_vector(std::vector &data) { //std::vector ::iterator it; //可以用auto代替。 for(auto it_data = data.begin();it_data != data.end();it_data++){ std::cout << *it_data << " " << std::endl; } } void fun_vector() { vector data1; for(int i = 0;i < 6;i++){ data1.push_back(i); } fun_print_vector(data1); //打印 0 1 2 3 4 5 vector data2; data2 = data1; fun_print_vector(data2); //打印 0 1 2 3 4 5 vector data3; data3.assign(data1.begin(),data1.end()); fun_print_vector(data3); //打印 0 1 2 3 4 5 vector data4; data3.assign(3,6); fun_print_vector(data4); //打印 6 6 6 }
empty(); //判斷容器是否為空
capacity(); //容器的容量 capacity一定會大于等于size
size(); //返回容器中元素的個數(shù)
resize(int num); //重新指定容器的長度為num,若容器變長,則以默認(rèn)值填充新的位置;若容器變短,則末尾超出的元素被刪除
resize(int num,elem); //重新指定容器的長度為num,若容器變長,則以elem數(shù)值填充新的位置;若容器變短,則末尾超出的元素被刪除
#include#include using namespace std; void fun_print_vector(std::vector &data) { //std::vector ::iterator it; //可以用auto代替。 for(auto it_data = data.begin();it_data != data.end();it_data++){ std::cout << *it_data << " " << std::endl; } } void fun_vector() { vector data1; for(int i = 0;i < 6;i++){ data1.push_back(i); } fun_print_vector(data1); //打印 0 1 2 3 4 5 if(data1.empty() == true){ std::cout << "該容器是空" << std::endl; }else{ std::cout << "該容器不是空" << std::endl; std::cout << "data1.capacity:" << data1.capacity() << std::endl; std::cout << "data1.size:" << data1.size() << std::endl; } data1.resize(10); //填充默認(rèn)值0 fun_print_vector(data1); //打印 0 1 2 3 4 5 0 0 0 0 data1.resize(13,8); //填充數(shù)值8 fun_print_vector(data1); //打印 0 1 2 3 4 5 0 0 0 0 8 8 8 data1.resize(4); fun_print_vector(data1); //打印 0 1 2 3 }
push_back(elem); //尾部插入元素elem
pop_back(); //刪除最后一個元素
insert(const_iterator pos, elem); //迭代器指向位置pos插入元素elem
insert(const_iterator pos, int count,elem); //迭代器指向位置pos插入count個元素elem
erase(const_iterator pos); //刪除迭代器指向的元素
erase(const_iterator start,const_iterator end); //刪除迭代器start到end之間的元素
clear(); //刪除容器中所有元素
#include#include using namespace std; void fun_print_vector(std::vector &data) { //std::vector ::iterator it; //可以用auto代替。 for(auto it_data = data.begin();it_data != data.end();it_data++){ std::cout << *it_data << " " << std::endl; } } void fun_vector() { vector data1; for(int i = 0;i < 6;i++){ data1.push_back(i); } fun_print_vector(data1); //打印 0 1 2 3 4 5 data1.pop_back(); //尾刪 fun_print_vector(data1); //打印 0 1 2 3 4 data1.insert(data1.begin(),22); //迭代器位置插入一個22 fun_print_vector(data1); //打印 22 0 1 2 3 4 data1.insert(data1.begin(),3,7); //迭代器位置插入三個22 fun_print_vector(data1); //打印 7 7 7 22 0 1 2 3 4 data1.erase(data1.begin()); //迭代器位置刪除 fun_print_vector(data1); //打印 7 7 22 0 1 2 3 4 data1.erase(data1.begin(),data1.end()); //迭代器位置 區(qū)間 刪除 fun_print_vector(data1); //打印 空 data1.clear(); //清空容器 fun_print_vector(data1); //打印 空 }
at(int idx); //返回索引idx所指的數(shù)據(jù)
operator []; //返回索引idx所指的數(shù)據(jù)
front(); //返回容器的第一個數(shù)據(jù)元素
back(); //返回容器的最后一個數(shù)據(jù)元素
#include#include using namespace std; void fun_print_vector(std::vector &data) { //std::vector ::iterator it; //可以用auto代替。 for(auto it_data = data.begin();it_data != data.end();it_data++){ std::cout << *it_data << " " << std::endl; } } void fun_vector() { vector data1; for(int i = 0;i < 6;i++){ data1.push_back(i); } //利用[]方式訪問vector中的元素 for(int j = 0;j 6. vector的呼喚容器函數(shù)原型:
swap(vec); //將vecy與本身 兩個容器中的元素互換
#include#include using namespace std; void fun_print_vector(std::vector &data) { //std::vector ::iterator it; //可以用auto代替。 for(auto it_data = data.begin();it_data != data.end();it_data++){ std::cout << *it_data << " " << std::endl; } } void fun_vector() { vector data1; for(int i = 0;i < 6;i++){ data1.push_back(i); } fun_print_vector(data1); //打印 0 1 2 3 4 5 vector data2; for(int i = 6;i > 0;i++){ data2.push_back(i); } fun_print_vector(data2); //打印 6 5 4 3 2 1 data1.swap(data2); fun_print_vector(data1); //打印 6 5 4 3 2 1 fun_print_vector(data2); //打印 0 1 2 3 4 5 } 關(guān)于“C++怎么使用std::vector容器”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“C++怎么使用std::vector容器”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
名稱欄目:C++怎么使用std::vector容器
網(wǎng)址分享:http://weahome.cn/article/ggephc.html