亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++ Vector用法詳解

2020-05-23 14:19:07
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了C++ Vector用法詳解,vector是C++標準模版庫(STL,Standard Template Library)中的部分內容,本文詳細介紹了它的方方面面,需要的朋友可以參考下
 

vector是C++標準模版庫(STL,Standard Template Library)中的部分內容。之所以認為是一個容器,是因為它能夠像容器一樣存放各種類型的對象,簡單的說:vector是一個能夠存放任意類型的動態數組,能夠增加和壓縮數據。

使用vector容器之前必須加上<vector>頭文件:#include<vector>;

vector屬于std命名域的內容,因此需要通過命名限定:using std::vector;也可以直接使用全局的命名空間方式:using namespace std;

vector成員函數

c.push_back(elem)在尾部插入一個elem數據。

復制代碼代碼如下:

vector<int> v;
    v.push_back(1);

c.pop_back()刪除末尾的數據。
復制代碼代碼如下:

vector<int> v;
    v.pop_back();

c.assign(beg,end)將[beg,end)一個左閉右開區間的數據賦值給c。
復制代碼代碼如下:

vector<int> v1,v2;
v1.push_back(10);
v1.push_back(20);
v2.push_back(30);
v2.assign(v1.begin(),v1.end());

c.assign (n,elem)將n個elem的拷貝賦值給c。
復制代碼代碼如下:

vector<int> v;

 

v.assign(5,10);//往v里放5個10


c.at(int index)傳回索引為index的數據,如果index越界,拋出out_of_range異常。
復制代碼代碼如下:

vecto<int> v;
cout << v.at(2) << endl;//打印vector中下標是2的數據

c.begin()返回指向第一個數據的迭代器。

 

c.end()返回指向最后一個數據之后的迭代器。

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
vector<int>::iterator it;
for(it = v.begin();it!=v.end();it++){
    cout << *it << "/t";
}
cout << endl;

 

c.rbegin()返回逆向隊列的第一個數據,即c容器的最后一個數據。

c.rend()返回逆向隊列的最后一個數據的下一個位置,即c容器的第一個數據再往前的一個位置。

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
vector<int>::reverse_iterator it;
for(it = v.rbegin();it!=v.rend();it++){
    cout << *it << "/t";
}
cout << endl;

 

c.capacity()返回容器中數據個數,翻倍增長。

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
cout << v.capacity() << endl;  // 1
v.push_back(2);
cout << v.capacity() << endl;  // 2
v.push_back(3);
cout << v.capacity() << endl; // 4

 

c.clear()移除容器中的所有數據。

 

復制代碼代碼如下:

vector<int>::iterator it;
for(it = v.begin();it!=v.end();it++){
    cout << *it << "/t";
}
v.clear();
for(it = v.begin();it!=v.end();it++){
    cout << *it << "/t";
}
cout << endl;

 

c.empty()判斷容器是否為空。

 

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
if(!v.empty()){
    cout << "v is not empty!" << endl;        
}

 

c.erase(pos)刪除pos位置的數據,傳回下一個數據的位置。

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.erase(v.begin());

 

c.erase(beg,end)刪除[beg,end)區間的數據,傳回下一個數據的位置。

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.erase(v.begin(),v.end());

c.front()返回第一個數據。

 

c.back()傳回最后一個數據,不檢查這個數據是否存在。

復制代碼代碼如下:

vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
if(!vec.empty()){
    cout << “the first number is:” << v.front() << endl;
    cout << “the last number is:” << v.back() << endl;
}

 

c.insert(pos,elem) 在pos位置插入一個elem的拷貝,返回插入的值的迭代器。

c.insert(pos,n,elem)在pos位置插入n個elem的數據,無返回值。

c.insert(pos,beg,end)在pos位置插入在[beg,end)區間的數據,無返回值。

復制代碼代碼如下:

vector<int> v;
v.insert(v.begin(),10);
v.insert(v.begin(),2,20);
v.insert(v.begin(),v1.begin(),v1.begin()+2);

 

c.size()返回容器中實際數據的個數。

c.resize(num)重新指定隊列的長度。(往往用來增加vector的長度,小->大 ok 大->小 沒用!)

c.reserve()保留適當的容量。

  針對resize()和reserver()做一點分析:

  reserve是容器預留空間,但并不真正創建元素對象,在創建對象之前,不能引用容器內的元素,因此當加入新的元素時,需要用push_back()/insert()函數。

  resize是改變容器的大小,并且創建對象,因此,調用這個函數之后,就可以引用容器內的對象了,因此當加入新的元素時,用operator[]操作符,或者用迭代器來引用元素對象。

  再者,兩個函數的形式是有區別的,reserve函數之后一個參數,即需要預留的容器的空間;resize函數可以有兩個參數,第一個參數是容器新的大小,第二個參數是要加入容器中的新元素,如果這個參數被省略,那么就調用元素對象的默認構造函數。

  reserve只是保證vector的空間大小(capacity)最少達到它的參數所指定的大小n。在區間[0, n)范圍內,如果下標是index,vector[index]這種訪問有可能是合法的,也有可能是非法的,視具體情況而定。
     resize和reserve接口的共同點是它們都保證了vector的空間大小(capacity)最少達到它的參數所指定的大小。

c.max_size()返回容器能容量的最大數量。

c1.swap(c2)將c1和c2交換。

swap(c1,c2)同上。

復制代碼代碼如下:

vector<int> v1,v2,v3;
v1.push_back(10);
v2.swap(v1);
swap(v3,v1);

 

vector<type>c;創建一個空的vector容器。

vector<type> c1(c2);復制一個vector。

vector<type> c(n);創建一個vector,含有n個數據,數據均以缺省構造產生,即全0;

vector<type> c(n,elem)創建一個vector,含有n個elem的拷貝數據。

vector<type> c(beg,end)創建一個以[beg,end)區間的vector。

~vector<type>()   銷毀所有數據,施放內存。

壓縮一個臃腫的vector

很多時候大量的刪除數據,或者通過使用reserver(),結果vector的空間遠遠大于實際的需要。所以需要壓縮vector到它的實際大小。resize()能增加vector的大小。clear()僅僅移除容器內的數據,不能改變capacity()的大小,所以對vector進行壓縮非常重要。

測試一下clear()函數:

復制代碼代碼如下:

//
//  vector.cpp
//  vector
//
//  Created by scandy_yuan on 13-1-7.
//  Copyright (c) 2013年 Sam. All rights reserved.
//

 

#include <iostream>
#include <vector>
using namespace std;
int main(int argc, const char * argv[])
{

    // insert code here...
    vector<int> v;
    v.push_back(1);
    v.push_back(2);
    v.push_back(3);
    vector<int>::iterator it;
    cout << "clear before:" << " ";
    for(it=v.begin();it!=v.end();it++){
        cout << *it << "/t";
    }
    cout << endl;
    cout << "clear before capacity:" << v.capacity() << endl;
    v.clear();
    cout << "after clear:" << " ";
    for(it=v.begin();it!=v.end();it++){
        cout << *it << "/t";
    }
    cout << endl;
    cout << "after clear capacity:" << v.capacity() << endl;
    return 0;
}

 

結果:

復制代碼代碼如下:

clear before: 1    2    3    
clear before capacity:4
after clear: 
after clear capacity:4

為什么這里打印的capacity()的結果是4不做詳細解釋,請參考上面關于capacity的介紹。 通過結果,我們可以看到clear()之后數據全部清除了,但是capacity()依舊是4。

 

假設:我們通過原本的vector來創建一個新的vector,讓我們看看將會發生什么?

復制代碼代碼如下:

//
//  vector.cpp
//  vector
//
//  Created by scandy_yuan on 13-1-7.
//  Copyright (c) 2013年 Sam. All rights reserved.
//

 

#include <iostream>
#include <vector>
using namespace std;
int main(int argc, const char * argv[])
{

    // insert code here...
    vector<int> v;
    v.push_back(1);
    v.push_back(2);
    v.push_back(3);
    cout << "v.capacity()" << v.capacity() << endl;
    
    vector<int> v1(v);
    cout << "v1.capacity()" << v1.capacity() << endl;
    return 0;
}

 

結果:

復制代碼代碼如下:

v.capacity()4
v1.capacity()3

可以看出,v1的capacity()是v的實際大小,因此可以達到壓縮vector的目的。但是我們不想新建一個,我們想在原本的vector(即v)上進行壓縮,那么借鑒上面的方式思考另一種方式。

 

假設:我們通過swap函數把v1交換回v,看看會發生什么?

復制代碼代碼如下:

//
//  vector.cpp
//  vector
//
//  Created by scandy_yuan on 13-1-7.
//  Copyright (c) 2013年 Sam. All rights reserved.
//

 

#include <iostream>
#include <vector>
using namespace std;
int main(int argc, const char * argv[])
{

    // insert code here...
    vector<int> v;
    v.push_back(1);
    v.push_back(2);
    v.push_back(3);
    cout << "v.capacity()" << v.capacity() << endl;
    
    vector<int> v1(v);
    cout << "v1.capacity()" << v1.capacity() << endl;
    
    v.swap(v1);
    cout << "v.swap(v1).capacity()" << v.capacity() << endl;
    return 0;
}

 

結果:

復制代碼代碼如下:

v.capacity()4
v1.capacity()3
v.swap(v1).capacity()3

可以看出,v.capacity()變成了3,目的達到。但是代碼給人感覺繁瑣臃腫,我們從新考慮一種新的寫法,采用匿名對象來代替v1這個中間對象:vector<int> (v).swap(v);

 

測試:

復制代碼代碼如下:

//
//  vector.cpp
//  vector
//
//  Created by scandy_yuan on 13-1-7.
//  Copyright (c) 2013年 Sam. All rights reserved.
//

 

#include <iostream>
#include <vector>
using namespace std;
int main(int argc, const char * argv[])
{

    // insert code here...
    vector<int> v;
    v.push_back(1);
    v.push_back(2);
    v.push_back(3);
    cout << "v.capacity()" << v.capacity() << endl;
    
    vector<int> (v).swap(v);
    cout << "v.capacity()" << v.capacity() << endl;
    return 0;
}

 

結果:

復制代碼代碼如下:

v.capacity()4
v.capacity()3

可以看到 v.capacity()由4編程了3,目的達到。

 

之前沒有關注C++11,感謝@egmkang,確實在C++11中已經提供了shrink_to_fit()函數實現vector的壓縮。

如下:

復制代碼代碼如下:

#include <iostream>
#include <vector>
int main()
{
    std::vector<int> v;
    std::cout << "Default-constructed capacity is " << v.capacity() << '/n';
    v.resize(100);
    std::cout << "Capacity of a 100-element vector is " << v.capacity() << '/n';
    v.clear();
    std::cout << "Capacity after clear() is " << v.capacity() << '/n';
    v.shrink_to_fit();
    std::cout << "Capacity after shrink_to_fit() is " << v.capacity() << '/n';
}

 

結果:

復制代碼代碼如下:

Default-constructed capacity is 0
Capacity of a 100-element vector is 100
Capacity after clear() is 100
Capacity after shrink_to_fit() is 0

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久噜久噜久久综合| 性亚洲最疯狂xxxx高清| 久久大大胆人体| 日韩精品中文字幕视频在线| 日韩电影视频免费| 日韩欧美在线播放| 国产亚洲免费的视频看| 成人精品久久一区二区三区| 亚洲xxxxx性| 成人午夜两性视频| 日韩hd视频在线观看| 亚洲色在线视频| 欧美日韩免费观看中文| 亚洲视频欧洲视频| 国产丝袜一区二区三区免费视频| 福利视频导航一区| 另类少妇人与禽zozz0性伦| 日韩av一区在线| 亚洲男女自偷自拍图片另类| 成人国产精品一区二区| 亚洲精品二三区| 韩国国内大量揄拍精品视频| 亚洲国产精品va在线观看黑人| 欧美成人午夜影院| 黄色精品一区二区| 操91在线视频| 日韩有码在线电影| 久久精品成人欧美大片古装| 成人免费自拍视频| 91理论片午午论夜理片久久| 亚洲人成在线电影| 成人在线播放av| 欧美亚洲一区在线| 中文字幕九色91在线| 欧美限制级电影在线观看| 狠狠躁夜夜躁人人躁婷婷91| 51精品国产黑色丝袜高跟鞋| 亚洲自拍高清视频网站| 欧美精品videosex极品1| 在线观看日韩视频| 热re99久久精品国产66热| 久久免费观看视频| 在线成人中文字幕| 国产乱肥老妇国产一区二| 日韩男女性生活视频| 欧美日韩亚洲网| 色偷偷888欧美精品久久久| 欧美最顶级丰满的aⅴ艳星| 精品久久久久久久大神国产| 亚洲精美色品网站| 精品视频—区二区三区免费| 国产精品自产拍高潮在线观看| 久久五月情影视| 不用播放器成人网| 国产成人精彩在线视频九色| 欧美成人免费视频| 日韩大胆人体377p| 91精品在线国产| 欧美日韩一二三四五区| 色狠狠久久aa北条麻妃| 亚洲国产小视频| 国产精品久久久久久超碰| 在线观看91久久久久久| 国产一区二区动漫| 亚洲视频免费一区| 日本不卡视频在线播放| 亚洲国产精品系列| 久久久精品一区二区| 国产精品专区一| 日本欧美一级片| 成人性教育视频在线观看| 欧美精品成人在线| 国产一区玩具在线观看| 欧美一区二区色| 久久在线免费观看视频| 久久久久国色av免费观看性色| 日韩在线观看你懂的| 欧美在线视频a| 亚洲色图在线观看| 91久久综合亚洲鲁鲁五月天| 久久99久久99精品免观看粉嫩| 欧美黑人又粗大| 久久999免费视频| 法国裸体一区二区| 国产热re99久久6国产精品| 欧美亚洲国产另类| 91精品国产综合久久香蕉最新版| 精品高清一区二区三区| 亚洲男人天堂2019| 日韩欧美中文字幕在线观看| 91精品国产91久久久久福利| 国产丝袜一区二区三区| 91精品国产综合久久香蕉最新版| 日韩免费av一区二区| 精品国产美女在线| 538国产精品一区二区免费视频| 欧美激情一区二区三区成人| 日韩av中文字幕在线免费观看| 97人洗澡人人免费公开视频碰碰碰| 欧美国产日韩在线| 欧美激情视频网| 国内精品国产三级国产在线专| 国产亚洲精品久久久久久牛牛| 欧美精品性视频| 亚洲国产精品99久久| 国产日韩欧美成人| 欧美精品午夜视频| 国产欧美精品日韩| 91极品女神在线| 国产欧美一区二区三区在线| 欧美成人四级hd版| 精品人伦一区二区三区蜜桃免费| 中文字幕九色91在线| 91丝袜美腿美女视频网站| 欧美一区二区影院| 欧美日韩精品在线| 中文字幕国产日韩| 久久久久久久影院| 97在线视频免费| 国产亚洲精品美女久久久久| 日本免费在线精品| 庆余年2免费日韩剧观看大牛| 日韩性xxxx爱| 自拍偷拍免费精品| 国产一区二区三区在线| 久久手机免费视频| 日韩精品免费在线播放| 中文字幕精品av| 97视频免费在线观看| 国产精品美女久久久久久免费| 在线观看久久久久久| 亚洲精品美女网站| 中文字幕久精品免费视频| 亚洲影视中文字幕| 日韩高清电影免费观看完整| 少妇高潮久久久久久潘金莲| 亚洲人成在线免费观看| 欧美黑人xxxx| 亚洲自拍偷拍第一页| 欧美成人中文字幕| 少妇高潮 亚洲精品| 亚洲成人网久久久| 欧洲日本亚洲国产区| 国产精品人成电影在线观看| 亚洲视频在线视频| 精品久久久一区| 国产偷亚洲偷欧美偷精品| 亚洲精品乱码久久久久久按摩观| 一区二区三区回区在观看免费视频| 国产精品高潮呻吟久久av黑人| 欧美裸体xxxx极品少妇软件| 国产精品视频内| 色妞欧美日韩在线| 久热精品视频在线观看| 欧美一区二区三区……| 在线观看欧美视频| 欧美中在线观看| 国产成一区二区| 久久这里只有精品视频首页| 国产日韩精品在线| 中文字幕亚洲综合| 欧美性xxxx极品hd满灌| 日韩精品在线观看一区| 成人在线免费观看视视频|