STL 之 map的用法

2022-04-28 23:51:17 字數 1461 閱讀 7985

下面舉例說明什麼是一對一的資料對映。比如乙個班級中,每個學生的學號跟他的姓名就存在著一一對映的關係,這個模型用map可能輕易描述,很明顯學號用int描述,姓名用字串描述(本篇文章中不用char *來描述字串,而是採用stl中string來描述),下面給出map描述**:mapmapstudent;

1.       map的建構函式

map共提供了6個建構函式,這塊涉及到記憶體分配器這些東西,略過不表,在下面我們將接觸到一些map的構造方法,

這裡要說下的就是,我們通常用如下方法構造乙個map:

mapmapstudent;

2.       資料的插入

在構造map容器後,我們就可以往裡面插入資料了。這裡講三種插入資料的方法:

第一種:用insert函式插入pair資料,下面舉例說明(以下**雖然是隨手寫的,應該可以在vc和gcc下編譯通過,

大家可以執行下看什麼效果,在vc下**入這條語句,遮蔽4786警告 #pragma warning (disable:4786) )

#include

#include

#include

using namespace std;

int main()

6.資料的清空與判空

清空map中的資料可以用clear()函式,判定map中是否有資料可以用empty()函式,它返回true則說明是空map

7.       資料的刪除

這裡要用到erase函式,它有三個過載了的函式,下面在例子中詳細說明它們的用法

#include

#include

#include

using namespace std;

int main()

mapmapstudent;

mapstudent.insert(pair(1, 「student_one」));

mapstudent.insert(pair(2, 「student_two」));

mapstudent.insert(pair(3, 「student_three」));

//如果你要演示輸出效果,請選擇以下的一種,你看到的效果會比較好

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

//自個加上遍歷**,列印輸出吧

}

STL之map的高階用法

stl之map的高階用法 stl中的容器map,對映和多重對映基於某一型別key的鍵集的存在,提供對t型別的資料進行快速和高效的檢索。對 map而言,鍵只是指儲存在容器中的某一成員。map不支援副本鍵,multimap支援副本鍵。map和multimap物件包涵了鍵和各個鍵有關的值,鍵 和值的資料型...

STL 中 map 的用法

說明 如果你具備一定的 c template知識,即使你沒有接觸過stl,這個文章你也應該可能較輕易的看懂。本人水平有限,不當之處,望大家輔正。一 map概述 map是stl的乙個關聯容器,它提供一對一 其中第乙個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值 的資料處...

C 中STL之map用法詳解

深夜無聊 把map的用法複習一遍 嘻嘻 標準庫map型別是一種以鍵 值 key value 儲存的資料型別。以下分別從以下的幾個方面總結 map物件的的定義和初始化 map物件的基本操作,重要包括新增元素,遍歷等1.1 pair型別的定義和初始化 pair型別是在有檔案utility中定義的,pai...