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);
說明:把數(shù)字3加到vec的末尾。
注意:vector 類型的變量要想增加元素,只能用push_back() 函數(shù)
for(int i = 0;i<vec.size();i++)
vec.push_back(i);
說明:將vec中的元素依次賦值為0 1 2 3 4 .......
在尾部刪除元素:pop_back(空)
vec.pop_back();
說明:刪除容器內(nèi)的最后一個(gè)元素,容器的size減1。
之后仍然能通過push_back()來在尾部增加元素
因?yàn)?code>pop_back()不會(huì)減小capacity.
讀取長度:size(空)
int len = vec.size();
說明:將vec的長度(也就是其中的元素的個(gè)數(shù))賦給len
改變大?。?/strong> resize(改變后的長度,(用哪個(gè)元素補(bǔ)全))
假設(shè)此時(shí)vec的長度為4
vec.resize(2); // 將vec的長度變?yōu)?,(注意vec是從0開始編號(hào),因此此時(shí)vec的最后一個(gè)元素為vec[1]),vec[2:n]均被舍棄 vec.resize(6,3); // 將vec的長度變?yōu)?,此時(shí)vec[4:5] 均被賦值為3
且,resize函數(shù)只能對(duì)vec的size進(jìn)行減小,而不能使得capacity減小
清空:clear()
vec.clear();
說明:把size設(shè)置成0,capacity不變。
檢測(cè)是否為空 :empty()
if(vec.empty())
cout<< "empty";
else
cout <<"full";
說明:對(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ī)硪黄褂肔ibmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
基于Opencv實(shí)現(xiàn)顏色識(shí)別
這篇文章主要為大家詳細(xì)介紹了基于Opencv實(shí)現(xiàn)顏色識(shí)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
C++線程優(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)問題的三種解法
約瑟夫環(huán)問題是算法中相當(dāng)經(jīng)典的一個(gè)問題,其問題理解是相當(dāng)容易的,并且問題描述有非常多的版本,并且約瑟夫環(huán)問題還有很多變形,通過這篇約瑟夫問題的講解,一定可以帶你理解透徹2021-06-06
Qt creator中項(xiàng)目的構(gòu)建配置和運(yùn)行設(shè)置的步驟
使用 Qt Creator 集成開發(fā)環(huán)境構(gòu)建和運(yùn)行程序是一件非常簡單的事情,一個(gè)按鈕或者一個(gè)快捷鍵搞定全部,本文主要介紹了Qt creator中項(xiàng)目的構(gòu)建配置和運(yùn)行設(shè)置的步驟,感興趣的小伙伴們可以參考一下2021-11-11

