c++ 中vector 常見用法
1、c++ 中 vector
vector
有兩個(gè)參數(shù),一個(gè)是size
,表示當(dāng)前vector
容器內(nèi)存儲(chǔ)的元素個(gè)數(shù),一個(gè)是capacity
,表示當(dāng)前vector在內(nèi)存中申請(qǐng)的這片區(qū)域所能容納的元素個(gè)數(shù)。
capacity
會(huì)隨著你的使用vector
內(nèi)置函數(shù)而動(dòng)態(tài)變化.
通常capacity
會(huì)比size大,如果往vector
中push_back
數(shù)據(jù),這樣就不用重新申請(qǐng)內(nèi)存和拷貝元素到新內(nèi)存區(qū)域了,便于節(jié)省時(shí)間。
vector
之間可以之間賦值或者作為函數(shù)的返回值
2、初始化
與數(shù)組的初始化一樣
vector<int> a = {11,2,3};
3、常用函數(shù)
#include <vector> #include <iostream> using namespace std; int main() { vector<int> vec; }
多維的 vector
用法與多維的 string
一樣。
在尾部添加元素:push_back
(要添加的元素)
vec.push_back(3);
說(shuō)明:把數(shù)字3加到vec的末尾。
注意:vector
類型的變量要想增加元素,只能用push_back()
函數(shù)
for(int i = 0;i<vec.size();i++) vec.push_back(i);
說(shuō)明:將vec中的元素依次賦值為0 1 2 3 4 .......
在尾部刪除元素:pop_back(空)
vec.pop_back();
說(shuō)明:刪除容器內(nèi)的最后一個(gè)元素,容器的size
減1。
之后仍然能通過(guò)push_back()
來(lái)在尾部增加元素
因?yàn)?code>pop_back()不會(huì)減小capacity
.
讀取長(zhǎng)度:size(空)
int len = vec.size();
說(shuō)明:將vec
的長(zhǎng)度(也就是其中的元素的個(gè)數(shù))賦給len
改變大?。?/strong> resize
(改變后的長(zhǎng)度,(用哪個(gè)元素補(bǔ)全))
假設(shè)此時(shí)vec
的長(zhǎng)度為4
vec.resize(2); // 將vec的長(zhǎng)度變?yōu)?,(注意vec是從0開始編號(hào),因此此時(shí)vec的最后一個(gè)元素為vec[1]),vec[2:n]均被舍棄 vec.resize(6,3); // 將vec的長(zhǎng)度變?yōu)?,此時(shí)vec[4:5] 均被賦值為3
且,resize
函數(shù)只能對(duì)vec
的size
進(jìn)行減小,而不能使得capacity
減小
清空:clear()
vec.clear();
說(shuō)明:把size
設(shè)置成0,capacity
不變。
檢測(cè)是否為空 :empty()
if(vec.empty()) cout<< "empty"; else cout <<"full";
說(shuō)明:對(duì)于 empty()
函數(shù),如果為空,則返回 true
,如果非空,則返回 false
到此這篇關(guān)于c++ 中vector 常見用法的文章就介紹到這了,更多相關(guān)c++ 中的vector 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Libmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法
下面小編就為大家?guī)?lái)一篇使用Libmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08基于Opencv實(shí)現(xiàn)顏色識(shí)別
這篇文章主要為大家詳細(xì)介紹了基于Opencv實(shí)現(xiàn)顏色識(shí)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07C++線程優(yōu)先級(jí)SetThreadPriority的使用實(shí)例
這篇文章主要介紹了C++線程優(yōu)先級(jí)SetThreadPriority的使用實(shí)例,較為詳細(xì)的講述了C++線程及其優(yōu)先級(jí)的用法,需要的朋友可以參考下2014-10-10詳解基于C++實(shí)現(xiàn)約瑟夫環(huán)問(wèn)題的三種解法
約瑟夫環(huán)問(wèn)題是算法中相當(dāng)經(jīng)典的一個(gè)問(wèn)題,其問(wèn)題理解是相當(dāng)容易的,并且問(wèn)題描述有非常多的版本,并且約瑟夫環(huán)問(wèn)題還有很多變形,通過(guò)這篇約瑟夫問(wèn)題的講解,一定可以帶你理解透徹2021-06-06Qt creator中項(xiàng)目的構(gòu)建配置和運(yùn)行設(shè)置的步驟
使用 Qt Creator 集成開發(fā)環(huán)境構(gòu)建和運(yùn)行程序是一件非常簡(jiǎn)單的事情,一個(gè)按鈕或者一個(gè)快捷鍵搞定全部,本文主要介紹了Qt creator中項(xiàng)目的構(gòu)建配置和運(yùn)行設(shè)置的步驟,感興趣的小伙伴們可以參考一下2021-11-11