C Vector用法(帶例程)

2021-08-19 23:52:24 字數 4560 閱讀 6813

介紹:

vector是可變大小陣列的序列容器。vector是連續儲存的,與陣列儲存相同,區別是大小是動態改變的,可隨機訪問,因此vector訪問速度快。vector在末尾刪除新增元素時相對高效,若在其他任意位置新增刪除元素則效率更低。

使用:

1、標頭檔案

#include

2、初始化

vectorvec;        //宣告乙個int型向量

vectorvec(5);     //宣告乙個初始大小為5的int向量

vectorvec(10, 1); //宣告乙個初始大小為10且值都是1的向量

vectorvec(tmp);   //宣告並用tmp向量初始化vec向量

vectortmp(vec.begin(), vec.begin() + 3);  //用向量vec的第0個到第2個值初始化tmp

int arr[5] = ;   

vectorvec(arr, arr + 5);      //將arr陣列的元素用於初始化vec向量

//說明:當然不包括arr[4]元素,末尾指標都是指結束元素的下乙個元素,

//這個主要是為了和vec.end()指標統一。

vectorvec(&arr[1], &arr[4]); //將arr[1]~arr[4]範圍內的元素作為vec的初始值

3、基本操作

(1). 容量

向量大小: vec.size();

向量最大容量: vec.max_size();

更改向量大小: vec.resize();

向量真實大小: vec.capacity();

向量判空: vec.empty();

減少向量大小到滿足元素所佔儲存空間的大小: vec.shrink_to_fit(); //shrink_to_fit

(2). 修改

多個元素賦值: vec.assign(); //類似於初始化時用陣列進行賦值

末尾新增元素: vec.push_back();

末尾刪除元素: vec.pop_back();

任意位置插入元素: vec.insert();

任意位置刪除元素: vec.erase();

交換兩個向量的元素: vec.swap();

清空向量元素: vec.clear();

(3)迭代器

開始指標:vec.begin();

末尾指標:vec.end(); //指向最後乙個元素的下乙個位置

指向常量的開始指標: vec.cbegin(); //意思就是不能通過這個指標來修改所指的內容,但還是可以通過其他方式修改的,而且指標也是可以移動的。

指向常量的末尾指標: vec.cend();

(4)元素的訪問

下標訪問: vec[1]; //並不會檢查是否越界

at方法訪問: vec.at(1); //以上兩者的區別就是at會檢查是否越界,是則丟擲out of range異常

訪問第乙個元素: vec.front();

訪問最後乙個元素: vec.back();

返回乙個指標: int* p = vec.data(); //可行的原因在於vector在記憶體中就是乙個連續儲存的陣列,所以可以返回乙個指標指向這個陣列。這是是c++11的特性。

(5)排序

std::sort(vec.begin(), vec.end());

bool comp(const int& a, const int& b)

else

4、例程

#include "stdafx.h"

#include

#include

#include

bool comp(const int& a, const int& b)

int main(int argc, char* argv)

/* for 迴圈結束後,it++ ,it已越界,因此下面**記憶體訪問越界錯誤 */

/*printf("end for loop value = %d\r\n", *it);*/

/* 重置大小 重置元素初始為0 */

vec.resize(10);

/* size 變成了10 */

printf("vec.size() = %d\r\n", vec.size());

printf("vec.max_size() = %d\r\n", vec.max_size());

printf("vec.capacity() = %d\r\n", vec.capacity());

printf("vec.empty() = %d\r\n", vec.empty());

/* 遍歷列印 */

printf("resize 10 loop printf:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

/* 遍歷修改 */

it = vec.begin();

for(i = 0; it != vec.end(); it++, i++)

/* 遍歷列印 */

printf("loop modify loop printf:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

/* 末尾新增乙個元素 */

printf("push_back loop printf:\r\n");

vec.push_back(10);

/* 這一句放到上一句之前的話,遍歷列印會列印許多無效資料,所以元素修改後最好重新定向迭代器 */

it = vec.begin();

for(; it != vec.end(); it++)

/* 移除最後乙個元素 */

printf("pop_back loop printf:\r\n");

vec.pop_back();

it = vec.begin();

for(; it != vec.end(); it++)

/* 移除begin+3 位置的元素 */

printf("erase loop printf:\r\n");

it = vec.begin();

it+=3;

vec.erase(it);

/* 移除後it指向後乙個元素,因為移除後後面的元素前移了 */

for(; it != vec.end(); it++)

/* 移除begin+3 後重新遍歷列印 */

printf("erase loop printf all:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

/* resize 10,resize 新增的元素預設值為0 */

printf("resize 10 loop printf:\r\n");

vec.resize(10);

it = vec.begin();

for(; it != vec.end(); it++)

/* 位置3插入元素,然後從當前位置列印,當前迭代器即為當前插入元素的位置 */

printf("insert 3 loop printf:\r\n");

it = vec.begin();

it+=3;

vec.insert(it, 3);

for(; it != vec.end(); it++)

/* 遍歷列印 */

printf("loop printf:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

vec.pop_back();

/* 元素翻轉 */

std::reverse(vec.begin(), vec.end());

printf("reverse loop printf:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

/* 排序 */

std::sort(vec.begin(), vec.end());

printf("sort loop printf:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

/* 自定義排序 */

std::sort(vec.begin(), vec.end(), comp);

printf("comp sort loop printf:\r\n");

it = vec.begin();

for(; it != vec.end(); it++)

it = std::find(vec.begin(), vec.end(), 5);

if(it != vec.end())

else

it = std::find(vec.begin(), vec.end(), 20);

if(it != vec.end())

else

return 0;

C map用法(帶例程)

介紹 map是stl的乙個關聯容器,它提供一對一 其中第乙個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值 的資料 處理能力,由於這個特性,它完成有可能在我們處理一對一資料的時候,在程式設計上提供快速通道。這裡說下map內部資料的組織,map內部自建一顆紅黑樹 一 種非...

c vector 基本用法

include a.push back x x 為插入的資料out coll.erase coll.begin i,coll.begin j 刪除區間 i 1,j coll.erase coll.begin 2,coll.begin 5 刪除區間 3,5 coll.erase coll.begin ...

C vector用法初記

建立一維vector vector nums 不指定長度 vector nums n 指定長度為n新增元素 nums.push back 1 直接從陣列末端新增 nums i 1 直接賦值給第i個位置刪除元素 nums.resize nums.size i 直接將陣列長度減小,某種方式上刪掉了後面i...