C++ vector和list的區別
阿新 • • 發佈:2019-04-22
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;
如果需要大量的插入和刪除,而不關心隨機存取