99热这里只有精品2-99热这里只有精品6免费-99热这里只有精品国产99-99热这里只有精品国产99热门精品-99热这里只有精品国产动漫

編程代碼
新聞詳情

C++ vector和list的區別

發布時間:2020-12-28 10:49:11 瀏覽次數:2455

1.vector數據結構
vector和數組類似,擁有一段連續的內存空間,并且起始地址不變。
因此能高效的進行隨機存取,時間復雜度為o(1);
但因為內存空間是連續的,所以在進行插入和刪除操作時,會造成內存塊的拷貝,時間復雜度為o(n)。
另外,當數組中內存空間不夠時,會重新申請一塊內存空間并進行內存拷貝。

2.list數據結構
list是由雙向鏈表實現的,因此內存空間是不連續的。
只能通過指針訪問數據,所以list的隨機存取非常沒有效率,時間復雜度為o(n);
但由于鏈表的特點,能高效地進行插入和刪除。

3.vector和list的區別
我們看一個簡單的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;  //編譯錯誤,list沒有重載[]
    cout<<(v.begin()<v.end())<<endl; 
    //cout<<(l.begin()<l.end())<<endl; /編譯錯誤,list::iterator沒有重載<或>
    cout<<*(v.begin()+1)<<endl;
    //cout<<*(l.begin()+1)<<endl; //編譯錯誤,list::iterator沒有重載+
    vector<int>::iterator itv=v.begin();
    list<int>::iterator itl=l.begin();
    itv = itv+2;
    //itl=itl+2; //編譯錯誤,list::iterator沒有重載+
    itl++; //list::iterator中重載了++,只能使用++進行迭代訪問。
    itl++;
    cout<<*itv<<endl;
    cout<<*itl<<endl;
    getchar();
    return 0;
}

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

list的內存空間可以是不連續,它不支持隨機訪問,
因此list<int>::iterator則不支持“+”、“+=”、“<”等

vector<int>::iterator和list<int>::iterator都重載了“++”運算符。

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

在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13310869691
主站蜘蛛池模板: 国产精品久久久久久久久久日本 | 国产精品亚洲精品不卡| 亚洲国产成人影院播放| 一级免费视频| 日韩一区二区三区四区区区| 护士一级aaaaaa毛片| 国产亚洲一区二区三区在线| 美女黄污网站| 99久久婷婷国产综合精品hsex| 久996视频精品免费观看| 午夜一区二区三区| 在线播放一区二区精品产| 大伊香蕉精品视频在线天堂| 日韩免费a级在线观看| 亚洲精品综合一二三区在线| 免费播放成人生活片| 国产一国产一级毛片视频| 国产精品99久久| 美国一级大黄一片免费的网站| 2020亚洲欧美日韩在线观看| 国产精品大尺度尺度视频| 精品在线观看免费| 欧美成人午夜| 日本xxxx色视频在线观看| 亚洲精品一级一区二区三区| 在线精品国精品国产不卡| 一级a性色生活片久久毛片| 久久国产乱子免费精品| 日本高清aⅴ毛片免费| 中文字幕第一页在线| 可以免费观看的毛片| 亚洲国产精品一区二区三区久久| 成人午夜国产福到在线不卡| 免费在线观看小视频| 欧美人一级淫片a免费播放| 国内精品视频九九九九| 国产三级全黄| 国产www在线观看| 国产片在线看| 国产一区在线看| 国产91免费视频|