map基本用法

2021-08-21 16:12:16 字數 2110 閱讀 3004

目錄引言

1.map簡介

2.map的功能

3.使用map

4.map的建構函式

5. map的大小

6.map的基本操作函式

map是stl的乙個關聯容器,它提供一對一(其中第乙個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值)的資料 處理能力,由於這個特性,它完成有可能在我們處理一對一資料的時候,在程式設計上提供快速通道。這裡說下map內部資料的組織,map內部自建一顆紅黑樹(一 種非嚴格意義上的平衡二叉樹),這顆樹具有對資料自動排序的功能,所以在map內部所有的資料都是有序的,後邊我們會見識到有序的好處。

map是一類關聯式容器。它的特點是增加和刪除節點對迭代器的影響很小,除了那個操作節點,對其他的節點都沒有什麼影響。

對於迭代器來說,可以修改實值,而不能修改key。

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

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

快速插入key -value 記錄。

快速刪除記錄

根據key 修改value記錄。

遍歷所有記錄。

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

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

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

std:map<int,string> personnel;

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

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

typedefmap<int,cstring> udt_map_int_cstring;

udt_map_int_cstring enummap;

mapmymap;

在往map裡面插入了資料,我們怎麼知道當前已經插入了多少資料呢,可以用size函式,用法如下:

int nsize=mymap.size();

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的函式

map的基本用法

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

stl中map的基本用法

c maps是一種關聯式容器,包含 關鍵字 值 對 c maps 被用作儲存 關鍵字 值 對 語法 iterator begin begin 函式返回乙個迭代器指向map的第乙個元素。語法 void clear clear 函式刪除map中的所有元素。語法 size type count const...

map迭代器的基本用法

stl官方描述太過複雜,總結有以下幾種用法 begin 返回指向map頭部的迭代器 clear 刪除所有元素 count 返回指定元素出現的次數 empty 如果map為空則返回true end 返回指向map末尾的迭代器 equal range 返回特殊條目的迭代器對 erase 刪除乙個元素 f...