STL容器:vector
阿新 • • 發佈:2018-11-11
https://download.csdn.net/download/q2213065359/10684839
C&C++及STL參考手冊 中文及英文兩種
附:容器
容器分為 序列式容器 和 關聯式容器。
序列式容器主要有:vector,list,deque
關聯式容器主要有:map,multimap,set,multiset
序列式容器強調值的排序,而關聯式容器則在值中選擇一個值作為一個關鍵字,這個關鍵字起到
對值的索引的作用,方便查詢。值得注意的是關聯式容器中的set和map分辨只有值和關鍵字的區分
其對應的multiset和mulitmap分別對它們進行了擴充套件,均有值和關鍵字。
vector容器
一 介紹
- vector是表示可變大小陣列的序列容器。
- 就像陣列一樣,vector也採用的連續儲存空間來儲存元素。也就是意味著可以採用下標對vector的元素進行訪問,和陣列一樣高效。但是又不像陣列,它的大小是可以動態改變的,而且它的大小會被容器自動處理。
- 本質講,vector使用動態分配陣列來儲存它的元素。當新元素插入時候,這個陣列需要被重新分配大小為了增加儲存空間。其做法是,分配一個新的陣列,然後將全部元素移到這個陣列。就時間而言,這是一個相對代價高的任務,因為每當一個新的元素加入到容器的時候,vector並不會每次都重新分配大小。
- vector分配空間策略:vector會分配一些額外的空間以適應可能的增長,因為儲存空間比實際需要的儲存空間更大。不同的庫採用不同的策略權衡空間的使用和重新分配。但是無論如何,重新分配都應該是對數增長的間隔大小,以至於在末尾插入一個元素的時候是在常數時間的複雜度完成的。
- 因此,vector佔用了更多的儲存空間,為了獲得管理儲存空間的能力,並且以一種有效的方式動態增長。
- 與其它動態序列容器相比(deques, lists and forward_lists), vector在訪問元素的時候更加高效,在末尾新增和刪除元素相對高效。對於其它不在末尾的刪除和插入操作,效率更低。比起lists和forward_lists統一的迭代器和引用更好。
二 用法
1.標頭檔案
#include<vector>
2.定義方式
//幾種初始化
int arr[]={10,20,30,40,50};
vector<int> v1;//預設構造
vector<int> v2(arr,arr+sizeof(arr)/sizeof(int));//首地址和尾地址後面的地址
vector<int> v3(v2.begin,c2.end);//構造vector元素
vector<int> v4(v3);//複製構造
3 .api介面函式
v1.push_back() //在陣列的最後新增一個數據
v1.pop_back() //去掉陣列的最後一個數據
v1.front() //返回第一個元素(棧頂元素)
v1.begin() //得到陣列頭的指標,用迭代器接受
v1.end() //得到陣列的最後一個單元+1的指標,用迭代器接受
v1.clear() // 移除容器中所有資料
v1.empty() //判斷容器是否為空
v1.erase(pos) //刪除pos位置的資料
v1.erase(beg,end)// 刪除[beg,end)區間的資料
v1.size() //回容器中實際資料的個數
v1.insert(pos,data) //在pos處插入資料
4.使用迭代器訪問元素.
vector<int>::iterator it;
for(it=vec.begin();it!=vec.end();it++)
cout<<*it<<endl;
5.綜合例子
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main()
{
vector <int> v; //定義vector
vector<int>::iterator it; //定義一個vector迭代器
for(int i = 10; i >= 1; i--) //插入資料
v.push_back(i);
cout<<"輸出:";
for(it=v.begin();it!=v.end();it++) //輸出迭代器的值
cout<<*it<<" ";
cout<<endl;
it-=1;
cout<<"最後一個的值為:"<<*it<<" "<<endl;
v.erase(it); //刪除最後一個元素
cout <<"元素個數:" <<v.size() << endl; //輸出元素個數
sort(v.begin(), v.end()); //vector排序
cout<<"排序後:";
for(it=v.begin();it!=v.end();it++) //輸出vector元素
cout << *it << " ";
cout<<endl;
v.insert(v.begin(),100) ; //在pos位置插入一個elem
cout<<"第一個元素為:" <<v.front()<<endl;//輸出第一個元素
v.pop_back(); //去掉最後一個元素
cout << "元素個數:" <<v.size() << endl;//輸出元素個數
v.clear(); //vector清空
cout <<"清空後元素個數:" << v.size() << endl; //輸出元素個數
return 0;
}
具體介面函式文件裡面可以查詢 沒有積分的可以直接加我QQ2213065359 共同學習共同進步