1. 在c++中的詳細說明
vector是c++標準模板庫中的部分內容,它是乙個多功能的,能夠操作多種資料結構和演算法的模板類和函式庫。
vector之所以被認為是乙個容器,是因為它能夠像容器一樣存放各種型別的物件,
簡單地說,vector是乙個能夠存放任意型別的動態陣列,能夠增加和壓縮資料。
2. 使用vector,
必須在你的標頭檔案中包含下面的**:
#include
vector屬於std命名域,
建議使用全域性的命名域方式:
using namespace std;
3. 初始化
vector // 建立乙個空的vector。
vector c1(c2) // 複製乙個vector
vector c(n) // 建立乙個vector,含有n個資料,資料均已預設構造產生
vector c(n, elem) // 建立乙個含有n個elem拷貝的vector
vector c(beg,end) // 建立乙個含有n個elem拷貝的vector
4. 析構函式
c.~vector () // 銷毀所有資料,釋放記憶體
5. 成員函式
c.assign(beg,end)c.assign(n,elem)
將[beg; end)區間中的資料賦值給c。將n個elem的拷貝賦值給c。
c.at(idx)
傳回索引idx所指的資料,如果idx越界,丟擲out_of_range。
c.back() // 傳回最後乙個資料,不檢查這個資料是否存在。
c.begin() // 傳回迭代器中的第乙個資料位址。
c.capacity() // 返回容器中資料個數。
c.clear() // 移除容器中所有資料。
c.empty() // 判斷容器是否為空。
c.end() // 指向迭代器中末端元素的下乙個,指向乙個不存在元素。
c.erase(pos) // 刪除pos位置的資料,傳回下乙個資料的位置。
c.erase(beg,end) //刪除[beg,end)區間的資料,傳回下乙個資料的位置。
c.front() // 傳回第乙個資料。
get_allocator // 使用建構函式返回乙個拷貝。
c.insert(pos,elem) // 在pos位置插入乙個elem拷貝,傳回新資料位置。
c.insert(pos,n,elem) // 在pos位置插入n個elem資料。無返回值。
c.insert(pos,beg,end) // 在pos位置插入在[beg,end)區間的資料。無返回值。
c.max_size() // 返回容器中最大資料的數量。
c.pop_back() // 刪除最後乙個資料。
c.push_back(elem) // 在尾部加入乙個資料。
c.rbegin() // 傳回乙個逆向佇列的第乙個資料。
c.rend() // 傳回乙個逆向佇列的最後乙個資料的下乙個位置。
c.resize(num) // 重新指定佇列的長度。
c.reserve() // 保留適當的容量。
c.size() // 返回容器中實際資料的個數。
c1.swap(c2)
swap(c1,c2) // 將c1和c2元素互換。同上操作。
operator // 返回容器中指定位置的乙個引用。
STL之vector學習筆記
參考sgi stl 及 侯捷 stl原始碼剖析 概述 vector是動態空間,隨著元素的加入,它的內部機制會自行擴充空間以容納新元素。但是它不是單純地 配置新空間 資料移動 釋放舊空間,它實際配置的大小會比客戶需求要大一點定義 sgi stl的vector實現於stl vector.h中,而不是ve...
c STL 之 vector 學習筆記
定義乙個二維陣列 可以看作是乙個封裝好的動態陣列 vector int a 不止 int string char 型別,還可以自己定義結構體型別 結構體相關例題見?vector pta 7 10 宿舍誰最高?vector pta 7 7 計算職工工資 a.push back 10 插入 10 a.e...
C 11學習筆記2之vector
include include include using namespace std int main vb有1個元素,值為10 vectorvc 10,1 vc有10個元素,每乙個的值為1 vectorvd vd有2個元素,分別為10,1 return 0 是用來構造vector物件的 是用來列...