精品国产色欧洲激情_中文字幕在线欧美日韩制服在线_欢迎观看网站影片国产在线观看伊_日本高清一本视频_ww亚洲无码免费在线观看_午夜片无码区观看_欧美性爱福利资源_丰满少妇肥唇翘臀ⅩXX_欧美日韩另类久久_国内揄拍国内精品对白86

編程代碼
新聞詳情

C++ vector和list的區(qū)別

發(fā)布時(shí)間:2020-12-28 10:49:11 瀏覽次數(shù):2000

1.vector數(shù)據(jù)結(jié)構(gòu)
vector和數(shù)組類似,擁有一段連續(xù)的內(nèi)存空間,并且起始地址不變。
因此能高效的進(jìn)行隨機(jī)存取,時(shí)間復(fù)雜度為o(1);
但因?yàn)閮?nèi)存空間是連續(xù)的,所以在進(jìn)行插入和刪除操作時(shí),會(huì)造成內(nèi)存塊的拷貝,時(shí)間復(fù)雜度為o(n)。
另外,當(dāng)數(shù)組中內(nèi)存空間不夠時(shí),會(huì)重新申請(qǐng)一塊內(nèi)存空間并進(jìn)行內(nèi)存拷貝。

2.list數(shù)據(jù)結(jié)構(gòu)
list是由雙向鏈表實(shí)現(xiàn)的,因此內(nèi)存空間是不連續(xù)的。
只能通過指針訪問數(shù)據(jù),所以list的隨機(jī)存取非常沒有效率,時(shí)間復(fù)雜度為o(n);
但由于鏈表的特點(diǎn),能高效地進(jìn)行插入和刪除。

3.vector和list的區(qū)別
我們看一個(gè)簡(jiǎn)單的vector和list使用示例:

#include<iostream>
#include<vector>
#include<list>
using namespace std;
int main()
{
    vector<int> v;
    list<int> l;
    for(int i=0;i<8;i++) ////往v和l中分別添加元素
    {
        v.push_back(i);
        l.push_back(i);
    }
    cout<<"v[2]="<<v[2]<<endl;
    //cout<<"l[2]="<<l[2]<<endl;  //編譯錯(cuò)誤,list沒有重載[]
    cout<<(v.begin()<v.end())<<endl; 
    //cout<<(l.begin()<l.end())<<endl; /編譯錯(cuò)誤,list::iterator沒有重載<或>
    cout<<*(v.begin()+1)<<endl;
    //cout<<*(l.begin()+1)<<endl; //編譯錯(cuò)誤,list::iterator沒有重載+
    vector<int>::iterator itv=v.begin();
    list<int>::iterator itl=l.begin();
    itv = itv+2;
    //itl=itl+2; //編譯錯(cuò)誤,list::iterator沒有重載+
    itl++; //list::iterator中重載了++,只能使用++進(jìn)行迭代訪問。
    itl++;
    cout<<*itv<<endl;
    cout<<*itl<<endl;
    getchar();
    return 0;
}

vector擁有一段連續(xù)的內(nèi)存空間,能很好的支持隨機(jī)存取,
因此vector<int>::iterator支持“+”,“+=”,“<”等操作符。

list的內(nèi)存空間可以是不連續(xù),它不支持隨機(jī)訪問,
因此list<int>::iterator則不支持“+”、“+=”、“<”等

vector<int>::iterator和list<int>::iterator都重載了“++”運(yùn)算符。

總之,如果需要高效的隨機(jī)存取,而不在乎插入和刪除的效率,使用vector;
如果需要大量的插入和刪除,而不關(guān)心隨機(jī)存取,則應(yīng)使用list。

在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13822267203