溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++中如何利用Vector實現(xiàn)一個動態(tài)數(shù)組

發(fā)布時間:2022-04-14 11:10:26 來源:億速云 閱讀:240 作者:iii 欄目:編程語言

本篇內(nèi)容介紹了“C++中如何利用Vector實現(xiàn)一個動態(tài)數(shù)組”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

C++ 中 Vector 的使用

頭文件 #include <vector>  需要使用 std 命名空間 using namespace std;  以下使用方法以 int 數(shù)據(jù)類型為例,使用時可自定義數(shù)據(jù)類型  注意:下文中區(qū)間為左閉右開

1. 定義(初始化)Vector

vector<int> v; 創(chuàng)建一個空vector  vector<int> v(5); 創(chuàng)建一個vector,元素個數(shù)為 5  vector<int> v(5); 創(chuàng)建一個元素個數(shù)為 5 且每個元素的值均為 10 的 vector  vector<int> v2(v1); 復制另一個 vector 使 v2 與 v1 相等  vector<int> v(begin,end);復制[begin,end)區(qū)間內(nèi)另一個數(shù)組的元素到vector中

int a[]={2,4,6,8,10};vector<int> v(&a[1],&a[3]);

2. 向 Vector 中增加元素

v.push_back(x) 向尾部增加一個元素 x  v.insert(pos,x) 向pos地址指向元素前增加一個元素 x

v.insert(v.begin(),666); //在首元素前插入元素 666v.insert(v.begin()+1,666); //在第二個元素前插入元素 666

v.insert(pos,n,x) 向pos地址指向元素前增加 n 個相同的元素 x

v.insert(v.begin(),3,666); //在首元素前插入 3 個元素 666

v.insert(pos,first,last) 向pos地址指向元素前插入另一個相同類型向量[first,last)間的數(shù)據(jù)

v.insert(v.begin(),v2.begin(),v2.end()); //將v2所有元素插入v1之前

3. 刪除 Vector 中元素

v.pop_back() 刪除向量中最后一個元素  

v.clear() 清空向量中所有元素  

v.erase(pos) 刪除向量中迭代器指向元素

v.erase(v.begin()); //刪除首元素

v.erase(first,last): 刪除向量中[first,last)中元素

v.erase(v.begin()+1,v.end()-1); //刪除第二個到倒數(shù)第二個之間的元素

4. 遍歷 Vector 中元素

v[i] 直接訪問 Vector 中元素  v.at(pos)返回 pos 位置元素的值 pos下標從0開始 (類似數(shù)組)  

v.front() 返回首元素的值  v.back() 返回尾元素的值  

v.begin() 返回向量頭指針,指向第一個元素  v.end() 返回向量尾指針,指向向量最后一個元素的下一個位置  v.rbegin() 反向迭代器,指向最后一個元素  

v.rend() 反向迭代器,指向第一個元素之前的位置

//直接遍歷元素for(int i=0;i<v.size();i++){ cout<<v[i]<<" ";}//使用迭代器遍歷元素for(vector<int>::iterator i=v.begin();i<v.end();i++){ cout<<*i<<" ";}//使用反向迭代器遍歷元素(倒序輸出)for(vector<int>::reverse_iterator i=v.rbegin();i<v.rend();i++){ cout<<*i<<" ";}

5. 其他常用方法

v.empty() 判斷向量是否為空,為空返回1否則返回0  

v.size() 返回向量中元素的個數(shù)  

v.capacity() 返回當前向量所能容納的最大元素數(shù)量  

v.max_size() 返回最大可允許的vector元素數(shù)量值  v.swap(v2) 交換兩個同類型向量 v 和 v2  

v.assign(n,x) 把向量中第 n 個元素的值設為 x  v.assign(first,last) 將向量中[first,last)元素設置成當前向量元素

//將v中元素設置為v2中元素v.assign(v2.begin(),v2.end());

“C++中如何利用Vector實現(xiàn)一個動態(tài)數(shù)組”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(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)容。

AI