注:本文內容摘自網絡,准確性有待驗證,現階段僅供學習參考。尊重作品作者成果,原文鏈接 :http://blog.csdn.net/wxdcxp/article/details/5279618
首先,vector是序列式容器而set是關聯式容器。set包含0個或多個不重復不排序的元素,也就是說set能夠保證它裡面所有的元素都是不重復的。另外對set容器進行插入時可以指定插入位置或者不指定插入位置。如insert(v.begin(),1),也可以直接用insert(1)。還有一點是set對一些操作符沒有進行重載,如<
下面是舉個例子:
vector插入及遍歷:
#include <iostream>
#include <list>
#include <vector>
#include <deque>
#include <set>
using namespace std;
int main(void)
{
vector<int> v;
v.insert(v.begin(),1); //如果使用insert(1)不指定插入位置,會出錯
v.insert(v.begin(),2);
v.insert(v.begin(),1);
v.insert(v.begin(),3);
vector<int>::iterator vp = v.begin();
for(vp = v.begin();vp < v.end(); vp++)
cout << *vp << endl;
return 0;
}
運行程序輸出的結果是:
3
1
2
1
set插入及遍歷:
#include <iostream>
#include <list>
#include <vector>
#include <deque>
#include <set>
using namespace std;
int main(void)
{
set<int> v;
v.insert(v.begin(),1);
v.insert(v.begin(),2);
v.insert(v.begin(),1);
v.insert(v.begin(),3);
set<int>::iterator vp = v.begin();
//for(vp = v.begin();vp < v.end(); vp++) //如果使用這句會出錯,因為set容器對<沒有重載
while(vp!=v.end())
cout << *vp++ << endl;
return 0;
}
運行後結果是:
1
2
3
也就是說,set容器對有重復的元素只取其中的一個。
vector實現了數組的功能,可以隨機儲存,但是元素插入效率不高,因為要移動元素
list實現了鏈表的功能,不支持隨機儲存,元素insert操作比較高效,取元素操作比較低效
deque實現了雙端隊列的功能,兩端插入,刪除功能比較高效
set和上面的都不一樣,是復合容器
1,ArrayList 是新類,推薦使用,與Vector是舊類,不推薦使用;
2,HashSet 與HashTable 與HashMap 習慣用HashMap,因為習慣使用
HashMap的泛型,性能會更優;
3,List和Set都是接口。他們各自有自己的實現類,
有無順序的實現類,也有有順序的實現類。
最大的不同就是List是可以重復的。而Set是不能重復的。
List適合經常追加數據,插入,刪除數據。但隨即取數效率比較低。
Set適合經常地隨即儲存,插入,刪除。但是在遍歷時效率比較低。