1標頭檔案
#include
2、map的功能
自動建立key - value的對應。key 和 value可以是任意你需要的型別。
根據key值快速查詢記錄,查詢的複雜度基本是log(n),如果有1000個記錄,最多查詢10次,1,000,000個記錄,最多查詢20次。
快速插入key - value 記錄。
快速刪除記錄
根據key 修改value記錄。
遍歷所有記錄。
3,map的建構函式
map共提供了6個建構函式,這塊涉及到記憶體分配器這些東西,略過不表,在下面我們將接觸到一些map的構造方法,這裡要說下的就是,我們通常用如下方法構造乙個map:
mapmapstudent;
定義mapmy_map;
或者是typedefmapmy_map;
my_mapmy_map;
4,插入資料
(1)my_map["a"]=1;
改變map中的條目非常簡單,因為map類已經對操作符進行了過載
enummap[1] = "one";
enummap[2] = "two";
.....
這樣非常直觀,但存在乙個效能的問題。插入2時,先在enummap中查詢主鍵為2的項,沒發現,然後將乙個新的物件插入enummap,鍵是2,值是乙個空字串,插入完成後,將字串賦為"two"; 該方法會將每個值都賦為預設值,然後再賦為顯示的值,如果元素是類物件,則開銷比較大。我們可以用以下方法來避免開銷:
enummap.insert(map:: value_type(2, "two"))
(2)my_map.insert(map::value_type("b",2));
(3)my_map.insert(pair("c",3));
(4)my_map.insert(make_pair("d",4));
5.查詢並獲取map中的元素
下標操作符給出了獲得乙個值的最簡單方法:
cstring tmp = enummap[2];
但是,只有當map中有這個鍵的例項時才對,否則會自動插入乙個例項,值為初始化值。
我們可以使用find()和count()方法來發現乙個鍵是否存在。
查詢map中是否包含某個關鍵字條目用find()方法,傳入的引數是要查詢的key,在這裡需要提到的是begin()和end()兩個成員,分別代表map物件中第乙個條目和最後乙個條目,這兩個資料的型別是iterator.
int nfindkey = 2; //要查詢的key
//定義乙個條目變數(實際是指標)
udt_map_int_cstring::iterator it= enummap.find(nfindkey);
if(it == enummap.end())
else
6, 迭代資料
for(my_itr=my_map.begin();my_itr!=my_map.end();++my_itr){}
7,map的大小
在往map裡面插入了資料,我們怎麼知道當前已經插入了多少資料呢,可以用size函式,用法如下:
int nsize = mapstudent.size();
8,,資料的清空與判空
清空map中的資料可以用clear()函式,判定map中是否有資料可以用empty()函式,它返回true則說明是空map
9,//如果要刪除1,用迭代器刪除
map::iterator iter;
iter = mapstudent.find(1);
mapstudent.erase(iter);
//如果要刪除1,用關鍵字刪除
int n = mapstudent.erase(1);//如果刪除了會返回1,否則返回0
//用迭代器,成片的刪除
//一下**把整個map清空
mapstudent.earse(mapstudent.begin(), mapstudent.end());
//成片刪除要注意的是,也是stl的特性,刪除區間是乙個前閉後開的集
Map的使用詳解(c )
map是stl的乙個關聯容器,它提供一對一 其中第乙個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值 的資料處理能力,由於這個特性,它完成有可能在我們處理一對一資料的時候,在程式設計上提供快速通道。這裡說下map內部資料的組織,map內部自建一顆紅黑樹 一種非嚴格意義上...
STL中map的使用詳解
map本質上乙個平衡二叉樹 更準確地說是紅黑樹 那麼每個節點存放乙個資料,預設是key和value打包成乙個資料pair,以pair的形式存放在節點的,由此來看,pair裡面可以放任何資料,前提是pair必須可以比較大小,當然也可以自定義比較函式,而map的第三個引數就是指定自定義key的比較函式的...
STL中map使用詳解
1.map中的建構函式 map 預設建構函式 map const map m 拷貝建構函式 map iterator begin,iterator end 區間建構函式 2.資料插入 insert pair key1,value1 例 mapmapstudent mapstudent.insert ...