std map set 区别

本文介绍了一个C++程序示例,展示了如何使用std::map和std::set容器来实现一对多的数据映射,并解释了map和set之间的主要区别。map允许将多个值映射到同一个键上,而set则确保每个元素都是唯一的。

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


  1 #include <map>

  2 #include <set>

  3 #include <iostream>

  4 

  5int main()

  6 {

  7        std::map<int, std::set<int> > map1;

  8        typedef std::map<int, std::set<int> >::iterator map_iter;

  9        typedef std::set<int>::iterator set_iter;

 10 

 11        for(int i=0; i<3; i++)

 12        {

 13                map1[i].insert(2);

 14                map1[i].insert(10);

 15                map1[i].insert(2);

 16        }

 17 

 18        int count = 0;

 19        for(map_iter cur = map1.begin(); cur != map1.end(); cur++, count++)

 20        {

 21                std::set<int> id = cur->second;

 22                for(set_iter i=id.begin(); i != id.end(); i++)

 23                        std::cout << *i << " ";

 24                std::cout << std::endl;

 25        }

 26 

 27        std::cout << << "map size = " <<  map1.size() << std::endl;

 28        return 0;

 29 }


 --  运行结果:     

2 10 

2 10 

2 10 

map size = 3


map 可以存 (1,2) (1, 10), (1,2) 重复的pair;

set 只存  (2,10)

 map 实现了 “一对多” 映射

 set 是一个集合,只不包括重复元素


std::mapstd::set是常用的关联式容器,它们都是ADT(抽象数据类型)。它们的接口不仅规定了操作的功能,还规定了操作的复杂度。例如,std::map的insert函数在通常情况下的复杂度是O(logN),其中N是元素的数量。但是如果插入的元素已经按照键值排序,那么复杂度将会是O(1)。\[1\] 在实现中,为了节约std::mapstd::set对象的大小,STL使用了空基类优化。具体做法是将rb_tree作为成员变量,而rb_tree又以rb_tree_impl为成员变量,rb_tree_impl继承自allocator。如果allocator是空类,那么rb_tree_impl的大小就和没有基类时一样。其他STL容器也使用了相同的优化措施,因此std::vector对象占用3个字长,std::list对象占用2个字长。boost的compressed_pair也使用了相同的优化。\[2\] 对于传递参数的方式,根据《Effective C++》的建议,我们应该尽量使用const引用来传递对象。但是对于内置类型、STL迭代器和STL仿函数,传值也是可以的,一般不会有性能损失。\[3\] #### 引用[.reference_title] - *1* *2* *3* [关于 std::set/std::map 的几个为什么](https://blog.youkuaiyun.com/Solstice/article/details/8521946)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值