解释一下std::unordered_map和map的区别
时间: 2023-10-21 20:31:23 浏览: 142
好的,std::unordered_map和map都是C++ STL库中的关联容器,但它们的实现机制不同。map是基于红黑树实现的,因此它的元素是按照一定的排序规则进行存储和访问的;而std::unordered_map则是基于哈希表实现的,它不会对元素进行排序,存储和访问元素的速度可能会更快,但是其内存使用可能会更高,因为哈希表需要维护一张哈希表来存储元素。因此,在选择使用map还是std::unordered_map时,需要根据具体的需求来判断哪一种更适合使用。
相关问题
cpp11std::unordered_map和std::unordered_set
cpp11std::unordered_map和std::unordered_set是C++11中引入的两个新容器。
cpp11std::unordered_map是一个无序关联容器,类似于std::map,但是它的元素是无序的。它使用哈希表来实现元素的存储和访问,因此它的查找和插入操作的时间复杂度为O(1)。它的元素可以是任意类型的,但是必须提供一个哈希函数和一个相等比较函数。
std::unordered_set也是一个无序容器,类似于std::set,但是它的元素是无序的。它也使用哈希表来实现元素的存储和访问,因此它的查找和插入操作的时间复杂度为O(1)。它的元素可以是任意类型的,但是必须提供一个哈希函数和一个相等比较函数。
这两个容器的使用方法与std::map和std::set类似,但是由于它们是无序的,因此它们的迭代器不支持比较操作。此外,它们还提供了一些特殊的操作,例如bucket_count()和load_factor(),用于查询哈希表的大小和负载因子。
std::unordered_set和std::unordered_map
std::unordered_set和std::unordered_map是C++ STL库中的两个容器,它们都是基于哈希表实现的。其中,std::unordered_set是一个无序的集合,它存储唯一的元素,而std::unordered_map是一个无序的关联数组,它存储键值对。这两个容器都比std::set和std::map更高效,因为它们的元素是通过哈希函数进行快速查找的,而不是通过比较函数进行查找的。
在使用std::unordered_set时,可以使用构造函数来初始化容器,并将元素插入到容器中。例如,可以使用以下代码初始化一个std::unordered_set并将"aaa"、"bbb"和"ccc"插入到容器中:
std::unordered_set<std::string> c{ "aaa", "bbb", "ccc" };
另外,也可以使用以下代码初始化一个具有16个桶的std::unordered_set:
std::unordered_set<std::string> c{ 16 };
在使用std::unordered_map时,可以使用insert()函数将键值对插入到容器中,也可以使用[]运算符来访问和修改元素。此外,还可以使用find()函数来查找特定的键是否存在于容器中。例如,可以使用以下代码查找键为key的元素是否存在于std::unordered_map中:
auto it = mymap.find(key);
if (it != mymap.end()) {
// key存在于mymap中
} else {
// key不存在于mymap中
}
阅读全文