C map函式的用法

2021-08-15 14:12:24 字數 4155 閱讀 6355

對map函式的一些整理

c++ map的基本操作和使用

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

1、map簡介

map是一類關聯式容器。它的特點是增加和刪除節點對迭代器的影響很小,除了那個操作節點,對其他的節點都沒有什麼影響。對於迭代器來說,可以修改實值,而不能修改key。

2、map的功能

自動建立key -value的對應。key 和value可以是任意你需要的型別。

根據key值快速查詢記錄,查詢的複雜度基本是log(n),如果有1000個記錄,最多查詢10次,1,000,000個記錄,最多查詢20次。

快速插入key - value 記錄。

快速刪除記錄 根據key 修改value記錄。 

遍歷所有記錄。

3、使用map

使用map得包含map類所在的標頭檔案 

#include //注意,stl標頭檔案沒有副檔名.h 

map物件是模板類,需要關鍵字和儲存物件兩個模板引數:

std:mappersonnel; 

這樣就定義了乙個用int作為索引,並擁有相關聯的指向string的指標. 

為了使用方便,可以對模板類進行一下型別定義,

typedef mapudt_map_int_cstring; 

udt_map_int_cstring enummap; 

4、在map中插入元素

改變map中的條目非常簡單,因為map類已經對操作符進行了過載 

enummap[1] = "one"; 

enummap[2] = "two"; 

..... 

這樣非常直觀,但存在乙個效能的問題。插入2時,先在enummap中查詢主鍵為2的項,沒發現,然後將乙個新的物件插入enummap,鍵是2, 值是乙個空字串,插入完成後將字串賦為"two"; 該方法會將每個值都賦為預設值,然後再賦為顯示的值,如果元素是類物件,則開銷比較大。我們可以用以下方法來避免開銷: 

enummap.insert(map:: value_type(2, "two"))

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  

通過map物件的方法獲取的iterator資料型別是乙個std::pair物件,包括兩個資料 iterator->first 和 iterator->second 分別代表關鍵字和儲存的資料 

6、從map中刪除元素

移除某個map中某個條目用erase() 

該成員方法的定義如下

iterator erase(iterator it); //

通過乙個條目物件刪除

iterator erase(iterator first, iterator last); //

刪除乙個範圍

size_type erase(const key& key); //

通過關鍵字刪除clear()

就相當於

enummap.erase(enummap.begin(), enummap.end()); 

1. map最基本的建構函式;

mapmapstring; 

mapmapint; 

mapmapstring; 

map< char ,string>mapchar; 

mapmapchar; 

mapmapint;

2. map新增資料;

mapmaplive; 

1.maplive.insert(pair(102,"aclive")); 

2.maplive.insert(map::value_type(321,"hai")); 

3, maplive[112]="april";//map中最簡單最常用的插入新增!

3.map中元素的查詢:

find()函式返回乙個迭代器指向鍵值為key的元素,如果沒找到就返回指向map尾部的迭代器。

map::iterator l_it;; 

l_it=maplive.find(112); 

if(l_it==maplive.end()) 

cout<<"we do not find 112"如果刪除112;

map::iterator l_it;

l_it=maplive.find(112); 

if(l_it==maplive.end()) 

cout<<"we do not find 112"maplive.erase(l_it);

//delete 112; 

5,map中swap的用法:

map中的swap不是乙個容器中的元素交換,而是兩個容器交換;

for example:

#include 

#include 

using namespace std; 

int main( )

6.map的sort問題:

map中的元素是自動按key公升序排序,所以不能對map用sort函式: 

for example:

#include 

#include 

using namespace std; 

int main( ) 

the original map m1 is: 

1 20 

2 50 

3 60 

4 40 

6 40 

7 30 

請按任意鍵繼續. . . 

7,map的基本操作函式:

c++ maps是一種關聯式容器,包含「關鍵字/值」對

begin()             返回指向map頭部的迭代器 

clear()            刪除所有元素 

count()            返回指定元素出現的次數

empty()           如果map為空則返回true 

end()               返回指向map末尾的迭代器 

equal_range()   返回特殊條目的迭代器對

erase()             刪除乙個元素

find()               查詢乙個元素

get_allocator()  返回map的配置器

insert()            插入元素

key_comp()      返回比較元素

key的函式lower_bound()   返回鍵值》=給定元素的第乙個位置

max_size()       返回可以容納的最大元素個數

rbegin()            返回乙個指向map尾部的逆向迭代器

rend()              返回乙個指向map頭部的逆向迭代器

size()               返回map中元素的個數

swap()             交換兩個map 

upper_bound() 返回鍵值》給定元素的第乙個位置

value_comp()   返回比較元素value的函式

C map函式的用法

stl中的map函式是將 key,value 資料以紅黑樹儲存的容器 其中關鍵字 key 只出現一次 map的定義 map mp 定義了乙個名為m的空的map物件 map mp m2 建立了m2的副本mp map的插入 map可以自動建立key value的對應。key 和 value可以是任意你需...

CMap類的用法

定義 cmapmymap 16 賦值 for int i 0 i 10 i mymap.setat i,cpoint i,i 賦完值後就變成如下這樣 索引 值 0 0,0 1 1,1 2 2,2 3 3,3 4 4,4 5 5,5 6 6,6 7 7,7 8 8,8 9 9,9 關鍵字為int型 比...

C MAP 基本用法

map內部資料的組織,map內部自建一顆紅黑樹 一種非嚴格意義上的平衡二叉樹 這顆樹具有對資料自動排序的功能,所以在map內部所有的資料都是有序的。include include using namespace std typedef mapmapstudent typedef map iterat...