關於C 中 map 的意義以及用法

2021-07-27 13:02:23 字數 2354 閱讀 3588

map,顧名思義就是地圖。其實就是key,value的對應。

當你需要快速的獲取對應key的value的時候,就可以使用map了。例如乙個人是有名字,但是這個人還有其他的屬性,例如年齡,性別等等。這個人就會被封裝為乙個物件。如果有很多個人,我們需要快速的根據乙個人的名字獲取對應名字的物件,這個時候map就有用了。如果採用陣列,我們需要遍歷整個陣列,才可以根據名字找到這個人。如果是map(以名字為key,以人的物件為value),就可以直接根據名字得到這個物件,就不需要遍歷操作了。

c++的map是採用紅黑樹實現的,因此獲取value的效率為lgn級別。

map的使用詳解

鍵值對 匹配

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的特性,刪除區間是乙個前閉後開的集

c 中map的用法

map是c 的乙個標準容器,她提供了很好一對一的關係,在一些程式中建立乙個map可以起到事半功倍的效果,總結了一些map基本簡單實用的操作!1.map最基本的建構函式 mapmapstring mapmapint mapmapstring map char string mapchar mapmap...

C 中Map的用法

map是一類關聯式容器。它的特點是增加和刪除節點對迭代器的影響很小,除了那個操作節點,對其他的節點都沒有什麼影響。對於迭代器來說,可以修改實值,而不能修改key。自動建立key value的對應。key 和 value可以是任意你需要的型別。根據key值快速查詢記錄,查詢的複雜度基本是log n 如...

c 中map的用法

map是c 的乙個標準容器,她提供了很好一對一的關係,在一些程式中建立乙個map可以起到事半功倍的效果,總結了一些map基本簡單實用的操作!1.map最基本的建構函式 mapmapstring mapmapint mapmapstring map char string mapchar mapmap...