您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“如何使用C++的vector”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
在C++中,官方文檔所給的創(chuàng)建對象方法有4-6種,博主這里便介紹其中最常用的4種,同時博主為了大家先能夠簡單使用,會省去一些與源文檔不一樣的地方.
直接創(chuàng)建,即和類定義對象一樣,官方聲明為:explicit vector ();,
其中explict
是指不支持隱式類型轉(zhuǎn)換.
示例:
vector<int> v1; //創(chuàng)建int類型順序表 v1; vector<char> v2; //創(chuàng)建char類型順序表 v2; vector<double> v3; //創(chuàng)建double類型順序表 v3;
通過傳n個val值定義對象,達到一創(chuàng)建對象就具有n個val,官方聲明為:explicit vector (size_type n, const value_type& val = value_type();,
其中value_type就是我們需要的類型…
示例:
vector<int> v1(10,9); //創(chuàng)建int類型順序表v1,里面有10個9; vector<int> v2(v1.begin(),v1.begin()+6); //創(chuàng)建int類型順序表v2,里面有6個9;
通過迭代器區(qū)間形式創(chuàng)建對象,官方聲明為:template <class InputIterator> vector (InputIterator first, InputIterator last).
示例:
vector<int> v1(10,9); //創(chuàng)建int類型順序表v1,里面有10個9; vector<int> v2(v1.begin(),v1.begin()+6); //創(chuàng)建int類型順序表v2,里面有6個9;
通過現(xiàn)成的同類型對象創(chuàng)建對象,官方聲明為:vector (const vector& x);.
示例:
vector<char> v1(10,9); //通過前面的方法創(chuàng)建一個對象; vector<char> v2(v1); //創(chuàng)建對象v2,其內(nèi)容與v1一模一樣.
在經(jīng)過前幾節(jié)的string洗禮,相信大家對迭代器也算比較了解,這里就直接開門見山的介紹用法吧:
普通迭代器接口:分別是begin()
和end();
其中begin()
為首元素位置,end()
為末元素位置下一個位置
反轉(zhuǎn)迭代器接口:分別是rbegin()和rend();
其中rbegin()
是末元素位置,rend()
是首元素前一個位置.
示例:
vector<int> v1; v1.push_back(1); v1.push_back(2); v1.push_back(3); v1.push_back(4); //這四個步驟大概意思為插入 1 2 3 4 vector<int>::iterator it = v1.begin(); while(it != v1.end()) { cout<<*it<<" "; } cout<<endl; //到這一步會輸出 1 2 3 4 it = v1.rbegin(); while(it != rend()) { cout<<*it<<" "; } cout<<endl; //到這一步會輸出4 3 2 1
在數(shù)據(jù)插入方面,C++最常用的兩個函數(shù)接口分別是insert和push_back.前者是在目標位置前插入,后者是進行尾插;
尾插 ,即對象直接調(diào)用push_back(),然后傳值進去.
vector<int> v1; //先創(chuàng)建一個對象. v1.push_back(1); //尾插數(shù)據(jù)1 v1.push_back(2); //尾插數(shù)據(jù)2 v1.push_back(3); //尾插數(shù)據(jù)3 // 現(xiàn)在v1的數(shù)據(jù)內(nèi)容情況為 1 2 3
而任意位置插入最常用的有3種,分別是
在pos位置直接插入一個元素,pos是一個迭代器
在pos位置直接插入n個元素,pos是一個迭代器
在pos位置插入一段區(qū)間(區(qū)間用迭代器表示),pos是一個迭代器
示例:
在刪除數(shù)據(jù)方面,主要有兩個接口,分別是erase()和pop_back(),前者是給一個迭代器,然后刪除.后者是尾刪,不需要參數(shù)
尾刪:
vector<int> v1; v1.push_back(1); v1.push_back(2); v1.push_back(3); v1.push_back(4); v1.pop_back(); //尾刪元素4 v1.pop_back(); //尾刪元素3 v1.pop_back(); //尾刪元素2 //目前該容器還剩下元素 1
傳迭代器形式刪除
vector<int> v1; v1.push_back(1); v1.push_back(2); v1.push_back(3); v1.push_back(4); v1.erase(v1.begin()); //刪除第一個元素1 v1.erase(v1.begin()+1); //刪除現(xiàn)在容容器的第二個元素3 //目前還剩下元素2 4
在這方面,c++提供了size(),resize(),capacity(),empty()
幾個常用操作.
獲取目前元素數(shù)量
vector<int> v1; v1.push_back(1); v1.push_back(2); v1.push_back(3); v1.push_back(4); v1.size(); //獲取到元素數(shù)量為4個
重新調(diào)整大小,其中如果傳入的n小于原來的size,那么容器就會縮減到n,同時傳入的另外參數(shù)無效;如果n大于size,就會擴大到n,參數(shù)有效,和string的使用一樣. 官方文檔為:void resize (size_type n, value_type val = value_type());
示例:
vector<int> v1; v1.push_back(1); v1.push_back(2); v1.push_back(3); v1.push_back(4); v1.resize(3,0); //只會縮減到3個size,傳入的另一個0無效 v1.resize(6,9); //現(xiàn)在6大于size:3,所以9有效 //現(xiàn)在內(nèi)容為1 2 3 9 9 9
獲取容量
vector<int> v1; v1.capacity(); //注意哦~,這個容量和size并不一樣.
判斷是否為空
示例:
vector<int> v1; if(v1.empty()) { cout<<"容易為空"<<endl; } else { cout<<"容器不為空"<<endl; }
“如何使用C++的vector”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。