C 中Map的用法

2021-08-01 11:01:41 字數 2949 閱讀 2226

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

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

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

快速插入key - value 記錄。

快速刪除記錄

根據key 修改value記錄。

遍歷所有記錄。

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

#include

<

map>

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

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

std:map

personnel;

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

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

typedef

map udt_map_int_cstring;

udt_map_int_cstring enummap;

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

enummap[1] = "one";

enummap[2] = "two";

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

enummap.insert(map

:: value_type(2, "two"))

下標操作符給出了獲得乙個值的最簡單方法:

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 分別代表關鍵字和儲存的資料

移除某個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());

c++ stl map的使用

以下是對c++中stl map的插入,查詢,遍歷及刪除的例子:

#include 

#include

#include

using

namespace

std;

void map_insert(map

< string, string > *mapstudent, string index, string x)

int main(int argc, char **argv)

else

//see element

for (iter = maps.begin(); iter != maps.end(); iter )

cout

<< "-----------------------------"

<< endl;

map_insert(&maps, "192.168.30.23", "xf");

cout

<< "after we insert one element:"

<< endl;

cout

<< "-----------------------------"

<< endl;

for (iter = maps.begin(); iter != maps.end(); iter )

cout

<< "-----------------------------"

<< endl;

//delete element

iter = maps.find("192.168.200.33");

if (iter != maps.end()) else

for (iter = maps.begin(); iter != maps.end(); iter )

cout

<< "******************************==="

<< endl;

return

0; }

c 中map的用法

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

c 中map的用法

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

c 中的map用法詳解

1.map最基本的建構函式 mapmapstring mapmapint mapmapstring map char string mapchar mapmapchar mapmapint 2.map新增資料 mapmaplive 1.maplive.insert pair 102,aclive 2...