c++中map的基本用法和嵌套用法

本文详细介绍了C++标准库中的map容器的基本用法,包括如何定义、插入、查找、修改和删除元素等,并通过示例展示了map容器的嵌套使用方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++中map容器提供一个键值对容器,map与multimap差别仅仅在于multiple允许一个键对应多个值。本文主要总结一下map基本用法和嵌套用法示例。

一、map基本用法
  1   头文件 
  #include   <map> 


  2   定义 
  map<int,   int>   my_Map; //注意这里的int和int可以是其他类型
  或者是typedef     map<int,   int>   MY_MAP; 
  MY_MAP   my_Map; 


  3   插入数据 
  (1)   my_Map[1]   =   1; 
  (2)   my_Map.insert(map<int, int>::value_type(2,2)); 
  (3)   my_Map.insert(pair<int,int>(3,3)); 
  (4)   my_Map.insert(make_pair<string,int>(4,4)); 
  
  4   查找数据和修改数据 
  (1)   int   i   =   my_Map[1]; 
            my_Map[1]   =   i; 
  (2)   MY_MAP::iterator   my_Itr; 
            my_Itr.find(2); 
            int   j   =   my_Itr->second; 
            my_Itr->second   =   j; 
注意:

A.键本身是不能被修改的,除非删除。 

B.不管键存不存在,比如my_Map[1]   =   i;,都会执行赋值操作。
  
  5   删除数据 
  (1)   my_Map.erase(my_Itr); 
  (2)   my_Map.erase(3); 

  
  6   遍历数据 
  for   (my_Itr=my_Map.begin();   my_Itr!=my_Map.end();   ++my_Itr)   {} 
  
  7   其它方法 
  my_Map.size() :返回元素数目 
  my_Map.empty():判断是否为空 
  my_Map.clear() :清空所有元素 

二、嵌套用法

1.示例如下:

    map<int,map<int,int> >multiMap; //对于这样的map嵌套定义,  
    map<int, int> temp;    //定义一个map<int, string>变量,对其定义后在插入multiMap  
    temp[9] = 9;  
    temp[10] = 10;  
    multiMap[10] = temp;  
    multiMap[10][11]=11;   
    multiMap[5][30]=30;  
    map<int,map<int,int> >::iterator multitr;  // 以下是如何遍历本multiMap  
    map<int,int>::iterator intertr;  
    for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)  
    { 
        for(intertr= multitr ->second.begin(); intertr != multitr ->second.end(); intertr ++)  
            cout<< multitr ->first<<" "<<intertr->first<<" ("<<intertr -> second <<")"<<endl;  
    } 

2.

也可以这样:

map<int,map<int,int>* >multiMap;
map<int, int>* temp = new map<int, int>;
multiMap[10]=temp;

这样动态new内存,就要记得delete,否则会有内存泄露,delete如下:

map<int, int>* temp1;
for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)  
{ 
	temp1 = multitr ->second;
        delete  temp1;
        temp1 = NULL;
} 


转载请注明原创链接:http://blog.youkuaiyun.com/wujunokay/article/details/12163549





### C++ 中 `map` 的嵌套使用方法 在 C++ 编程语言中,标准模板库(STL)提供了容器类 `std::map`,它是一个关联容器,用于存储键值对。通过将另一个 `map` 作为值类型的一部分,可以实现 `map` 的嵌套使用。 以下是关于如何定义、初始化以及操作嵌套 `map` 的详细说明: #### 定义嵌套 `map` 可以通过将一个 `map` 类型设置为另一个 `map` 的值来创建嵌套结构。例如,下面展示了如何声明一个两层嵌套的 `map`: ```cpp #include <iostream> #include <map> using namespace std; int main() { // 定义一个嵌套 map,外层 key 是 int,内层 key value 都是 int map<int, map<int, int>> nestedMap; // 插入数据到嵌套 map 中 nestedMap[1][2] = 3; // 表示 outerKey=1, innerKey=2, value=3 cout << "nestedMap[1][2]: " << nestedMap[1][2] << endl; // 输出 3 return 0; } ``` 此代码片段展示了一个简单的嵌套 `map` 结构及其基本用法[^1]。 #### 动态分配内存给内部 `map` 如果需要动态管理内部 `map` 的生命周期,则可以采用指针形式保存内部 `map` 并手动释放资源。以下是一段演示代码: ```cpp #include <iostream> #include <map> using namespace std; int main() { // 外部 map 存储指向内部 map 的指针 map<int, map<int, int>*> multiMap; // 创建一个新的内部 map 实例并将其赋值给外部 map 的某个位置 map<int, int>* temp = new map<int, int>(); (*temp)[5] = 10; // 向内部 map 添加元素 (key=5, value=10) multiMap[10] = temp; // 访问嵌套 map 数据 cout << "multiMap[10]->find(5)->second: " << multiMap[10]->at(5) << endl; // 清理动态分配的内存 for (auto& pair : multiMap) { delete pair.second; pair.second = nullptr; } return 0; } ``` 这段程序展示了如何利用指针管理清理嵌套 `map` 资源的方法[^2]。 #### 嵌套调用与递归调用的区别 虽然本问题主要讨论的是 `map` 的嵌套使用方式,但在某些场景下可能会涉及函数间的复杂交互模式。这里简单区分一下 **嵌套调用** **递归调用** 这两个概念: - **嵌套调用**:指的是在一个函数体内直接或间接调用了其他不同的函数。 - **递归调用**:特指某函数在其自身定义范围内再次被调用的情况。 两者都可以用来解决复杂的逻辑处理需求,但需要注意性能开销栈溢出等问题[^3]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值