【C++ STL】set这一类容器

2024-02-20 21:04
文章标签 c++ set 容器 stl 一类

本文主要是介绍【C++ STL】set这一类容器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

set这一类容器总共有四种:
  1. set
  2. multiset
  3. unordered_set
  4. unordered_multiset

这四种根据实现时使用的数据结构不同可以分成两大类:

一、使用红黑树实现的:setmultiset

setmultiset的相同点

时间复杂度:增删查改操作的平均时间复杂度是O(log n)

  • 插入元素的平均时间复杂度是 O ( l o g n ) O(log n) O(logn),因为容器内部使用红黑树(平衡二叉搜索树)实现,插入元素需要将元素按照顺序插入到合适的位置,红黑树的插入操作平均时间复杂度为 O ( l o g n ) O(log n) O(logn)
  • 删除元素的平均时间复杂度也是 O ( l o g n ) O(log n) O(logn),因为红黑树的删除操作也需要保持平衡,平均情况下的时间复杂度是 O ( l o g n ) O(log n) O(logn)
  • 查找元素的时间复杂度也是 O ( l o g n ) O(log n) O(logn),因为红黑树是一种有序的树结构,通过比较元素大小,在树中进行查找的时间复杂度是 O ( l o g n ) O(log n) O(logn)
  • 修改元素的时间复杂度也是 O ( l o g n ) O(log n) O(logn),因为需要先删除旧元素,然后插入新元素。

需要注意的是,这些时间复杂度是在平均情况下的估计,具体情况还取决于实际数据的分布和红黑树的性能。


迭代器:迭代器是双向迭代器,可以通过++和--操作来移动迭代器,并且还支持对迭代器所指向的元素进行修改

setmultiset的不同点

set中的元素不会重复,当插入集合中已有的元素时,并不会插入进去,而且set容器里的元素自动从小到大排序
multiset中的元素可以重复,且multiset容器里的元素自动从小到大排序

二、使用哈希表实现的:unordered_setunordered_multiset

unordered_setunordered_multiset的相同点

时间复杂度:增删查改操作的平均时间复杂度是O(1)

  • 插入元素的时间复杂度是O(1),因为容器内部使用哈希函数直接确定元素的插入位置,只需要常数时间即可完成插入。
  • 删除元素的时间复杂度也是O(1),同样是因为容器内部使用哈希函数定位到要删除的元素位置,然后直接删除。
  • 查找元素的时间复杂度也是O(1),因为容器内部使用哈希函数快速定位元素所在的桶,然后在桶中进行查找。
  • 修改元素的时间复杂度也是O(1),因为容器内部使用哈希函数快速定位元素所在的桶,然后在桶中进行修改。

需要注意的是,这是在平均情况下的时间复杂度,具体情况还取决于实际数据的分布和哈希函数的效果。在最坏情况下,当哈希函数将大量的元素映射到同一个桶中时,操作的时间复杂度可能会变为O(n)。但在平均情况下,增删查改操作时间复杂度为O(1)。


迭代器:迭代器是正向迭代器,只能通过++操作向后移动,不支持--操作。
且迭代器不支持修改操作,如果想修改元素的值,需要从容器中删除该元素,然后插入一个新的值。

unordered_setunordered_multiset的不同点

unordered_set元素无序只能出现一次
unordered_multiset元素无序可以出现多次


这篇关于【C++ STL】set这一类容器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/729541

相关文章

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注