1. 程式人生 > >STL容器:vector

STL容器:vector

https://download.csdn.net/download/q2213065359/10684839

C&C++及STL參考手冊 中文及英文兩種

附:容器

容器分為 序列式容器 和 關聯式容器。
序列式容器主要有:vector,list,deque
關聯式容器主要有:map,multimap,set,multiset
序列式容器強調值的排序,而關聯式容器則在值中選擇一個值作為一個關鍵字,這個關鍵字起到
對值的索引的作用,方便查詢。值得注意的是關聯式容器中的set和map分辨只有值和關鍵字的區分
其對應的multiset和mulitmap分別對它們進行了擴充套件,均有值和關鍵字。

                                                        vector容器

一 介紹

  1. vector是表示可變大小陣列的序列容器。
  2. 就像陣列一樣,vector也採用的連續儲存空間來儲存元素。也就是意味著可以採用下標對vector的元素進行訪問,和陣列一樣高效。但是又不像陣列,它的大小是可以動態改變的,而且它的大小會被容器自動處理。
  3. 本質講,vector使用動態分配陣列來儲存它的元素。當新元素插入時候,這個陣列需要被重新分配大小為了增加儲存空間。其做法是,分配一個新的陣列,然後將全部元素移到這個陣列。就時間而言,這是一個相對代價高的任務,因為每當一個新的元素加入到容器的時候,vector並不會每次都重新分配大小。
  4. vector分配空間策略:vector會分配一些額外的空間以適應可能的增長,因為儲存空間比實際需要的儲存空間更大。不同的庫採用不同的策略權衡空間的使用和重新分配。但是無論如何,重新分配都應該是對數增長的間隔大小,以至於在末尾插入一個元素的時候是在常數時間的複雜度完成的。
  5. 因此,vector佔用了更多的儲存空間,為了獲得管理儲存空間的能力,並且以一種有效的方式動態增長。
  6. 與其它動態序列容器相比(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 共同學習共同進步