首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【C++】STL 容器 - set 集合容器 ① ( set 集合容器简介 | set 集合容器操作的时间复杂度 | set 集合容器常用操作 )

一、set 集合容器 1、set 集合容器简介 C++ 语言中的 STL 容器中的 set 容器 , 是 " 集合容器 " , 容器中的 每个元素 是 " 唯一的 " , 并且 集合容器 中的元素 是按照一定的顺序进行排列的...; 向 set 集合容器 中 插入元素时 , 都会先验证集合中是否已经存在该元素 , 然后再根据排序规则 , 插入到指定的位置 ; set 集合容器 不支持 将 元素插入到指定位置 ; set 集合容器...也不支持 使用 下标位置 直接访问元素 ; 使用 set 集合容器前 , 需要 导入 set 头文件 ; #include "set" 与 set 容器类似的 容器还有 multiset 容器 , 唯一区别是...set 中的元素只能出现一次 , multiset 中的元素可以出现多次 ; set 集合容器 中的元素 不能直接修改 , 只能 先删除 原来的元素 , 然后插入新元素 ; 2、set 集合容器操作的时间复杂度...集合容器 的 插入 / 删除 操作 性能更高 ; 3、set 集合容器常用操作 set 集合容器常用操作 : 插入元素 : 调用 insert 函数 可以向 set 集合容器中插入元素 , 如果元素已存在

65810
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    介绍set和map容器

    在介绍set和map容器前先了解什么是关联式容器和键值对 1.什么是关联式容器 在初始阶段我们所学的STL容器当中,像vector,list,stack,queue等都是序列式容器,因为在其底层为线性序列的数据结构...3.树形结构的关联式容器 在STL当中一共实现两种不同的结构管理式容器:树形结构与哈希结构。树型结构的关联式容器主要有4种:map、set、multimap、multiset。...3.1set set 1.set是按照一定次序存储元素的容器 2.在set中,元素的value也标识它(value就是key,类型为T),并且每个value必须是唯一的。...set中的元素不能再容器中修改(元素总是const),但是可以从容器中插入或是删除它们。 3.再内部,set中的元素总是按照内部比较对象(类型比较)所指示的特定严格排序准则进行排序。...4.set容器通过key访问单个元素的速度通常比unordered_set慢,但是它们允许根据顺序对子集进行直接迭代 5.set咋底层是用红黑树实现的 注意: 1.与map/multimap不同

    9410

    【C++】STL 容器 - set 集合容器 ⑦ ( 查找元素 - set#find 函数 | 获取元素个数 - set#count 函数 )

    #find 函数 一、查找元素 - set#find 函数 1、函数原型 简介 在 C++ 语言的 STL 标准模板库 , std::set 集合容器 是一个存储唯一元素的容器 , 该容器的底层使用 红黑树...数据结构 实现 ; std::set 容器是有序的 , 存储元素时 会自动按指定规则进行排序 ; std::set 集合容器类 提供了一个 find 成员函数 , 用于查找 集合容器中 指定值的元素...0 或 1 ; 在 std::multiset 集合容器 中 , 统计元素个数是有意义的 ; std::set 集合容器类 提供了一个 count 成员函数 , 用于确定集合中特定元素的数量 ; 对于...std::set 来说 获取的结果只能是 0 或 1 ; 对于 std::multiset 容器 , 可以获取元素的个数 ; 这是为了保持与其他 关联容器的接口一致性 , 如 : std::multiset...无符号整数类型 , 表示指定元素 k 的数量 ; 如果 set 容器中 存在该值 , 返回 1 ; 如果 set 容器中 不存在该值 , 返回 0 ; 2、代码示例 - set#find 函数

    97810

    关联式容器set和map

    一.容器 在C++中容器大致可以分为两种,分别是:序列式容器和关联式容器。...关联式容器也有两类,一类是map,multimap和set,multiset这种底层为红黑树的容器,另一类是哈希结构。...T和一个仿函数以及空间配置器(STL中的容器为了减少扩容时的效率损失都是从内存池中开空间的),表面上set只有一个参数T,但其实set内部存放的是这样的键值对 set的大部分成员函数和...STL中其他的容器类似,所以就不一一介绍,这里只介绍具有set特性的成员函数 1.insert 第一个插入函数插入的参数是一个value_type的类型,其实这个类型是一个pair被typedef以后的名字...输入:nums1 = [1,2,2,1], nums2 = [2,2] 输出:[2] ---- 解题思路 输出结果要求每个元素都是唯一的,但是给定的两个数组中有可能出现重复的值,所以可以先使用set做容器存放给定的两个

    22020

    js中Set基本使用

    ECMAScript 6 新增的 Set 是一种新集合类型,为这门语言带来集合数据结构。Set 在很多方面都像是加强的 Map,这是因为它们的大多数 API 和行为都是共有的。 基本API 1....创建Set实例 使用 new 关键字和 Set 构造函数可以创建一个空集合: const s = new Set(); 如果想在创建的同时初始化实例,则可以给 Set 构造函数传入一个可迭代对象,其中需要包含插入到新集合实例中的元素...(Set 可以包含任何 JavaScript 数据类型作为值): const s = new Set(["val1", 1, true, {}, undefined, function fun() {}...]); 注意:Set结构不会添加重复的值 const s = new Set([1, 1, 2, 3, 4, 4, 5, 6, 7, 4, 2, 1]); Array.from(s); // [1,...Set实例转数组 const s = new Set([1, 2, 3]); Array.from(s); // [1, 2, 3] 3. size属性 size: 获取Set实例的元素个数: const

    2.6K30

    各类容器(set 、list、map)扩容机制

    当底层实现涉及到扩容时,容器或重新分配一段更大的连续内存(如果是离散分配则不需要重新分配,离散分配都是插入新元素时动态分配内存),要将容器原来的数据全部复制到新的内存上,这无疑使效率大大降低。...另外,扩容也是有默认的倍数的,不同的容器扩容情况不同。...Vector的容量为10,一次扩容后是容量为20 ArrayList:线程不安全,查询速度快 底层数据结构是数组结构 扩容增量:原容量的 0.5倍 如 ArrayList的容量为10,一次扩容后是容量为15 Set...(集) 元素无序的、不可重复 HashSet:线程不安全,存取速度快 底层实现是一个HashMap(保存数据),实现Set接口 默认初始容量为16(为何是16,见下方对HashMap的描述) 加载因子为

    2.1K00
    领券