博客
关于我
STL—set
阅读量:295 次
发布时间:2019-03-01

本文共 1550 字,大约阅读时间需要 5 分钟。

C++ set容器详解

什么是set

set意为集合,是一个内部自动有序且不含重复元素的容器。集合在编程中常用于存储和管理一系列唯一值,且这些值可以自动按照一定顺序排列。熟练掌握set容器,可以显著简化某些算法的实现,减少代码复杂度。使用set前,需要包含相应的头文件:

#include 

set的操作

1. set的定义

set的定义方式与vector类似,通用的定义格式为:

set
s;

其中,typename可替换为任意基本数据类型(如int, char, double)或自定义数据类型(如struct)。set还支持嵌套使用其他STL容器(如vectorsetqueue等)。

2. set内元素的访问

set容器只能通过迭代器(iterator)来访问元素。迭代器的使用方法与vector类似,定义方式如下:

set
::iterator it;

通过*it可以获取set中的当前元素。set的主要操作包括插入、查找、删除等,下文将详细讲解。

3. set的常用函数

(1)insert()

insert(x)用于将值x插入set中,set会自动排序并去重。该操作的时间复杂度为O(logN),其中N为set的元素个数。

(2)find()

find(value)返回一个指向匹配值value的迭代器。如果未找到对应值,则返回set的末尾迭代器。该操作的时间复杂度为O(logN)。

(3)erase()

erase()用于删除set中的元素。有两种形式:

  • s.erase(it):通过迭代器it删除指定元素,时间复杂度为O(1)。
  • s.erase(value):通过值value删除指定元素,时间复杂度为O(logN)。
  • (4)erase区间

    erase(first, last)用于删除区间[first, last)内的所有元素。firstlast分别是起始迭代器和结束迭代器的下一个位置。时间复杂度为O(N),其中N为删除区间的元素个数。

    (5)size()

    size()返回set中元素的总数,时间复杂度为O(1)。

    (6)clear()

    clear()清空set中的所有元素,时间复杂度为O(N),其中N为set的元素个数。

    set的实际应用示例

    #include 
    #include
    using namespace std;int main() { set
    s; s.insert(2); s.insert(-3); s.insert(7); s.insert(2); s.insert(4); s.insert(-10); for (auto it = s.begin(); it != s.end(); ++it) { cout << *it << ' '; } cout << endl; // 删除元素 s.erase(s.find(3)); for (auto it = s.begin(); it != s.end(); ++it) { cout << *it << ' '; } cout << endl; s.clear(); cout << s.size() << endl; return 0;}

    输出结果:

    -10 4 7-10 4 70

    通过以上代码示例,可以看到set容器的基本操作和实际应用效果。set的自动排序和去重功能使得开发人员在处理重复值和排序问题时大大减轻了工作负担。

    转载地址:http://wpsa.baihongyu.com/

    你可能感兴趣的文章
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
    查看>>
    NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_02---大数据之Nifi工作笔记0034
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_说明操作步骤---大数据之Nifi工作笔记0028
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>