c++集合(set)的介绍

在C++中,集合(set)是一种容器,它存储唯一的元素,而且这些元素按照某种排序规则自动排序。C++标准库提供了两种主要的集合类型:std::setstd::unordered_set。这两种集合都提供了一组方法来插入、删除、查找元素,并且它们的性能特点略有不同。

  1. std::set
    • std::set 是基于红黑树实现的有序集合。它的元素按照排序规则自动排序,并且不允许重复元素。
    • 插入、删除、查找操作的时间复杂度都是 O(log n),其中 n 是集合中元素的数量。
    • std::set 的元素是不可变的,一旦插入到集合中就不能修改。
    • 需要包含头文件 <set>
cpp 复制代码
#include <iostream>
#include <set>

int main() {
    std::set<int> mySet;

    // 插入元素
    mySet.insert(10);
    mySet.insert(5);
    mySet.insert(15);
    mySet.insert(5); // 不会被插入,因为集合中已经存在相同的元素

    // 遍历集合
    for (int num : mySet) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    // 删除元素
    mySet.erase(10);

    // 查找元素
    if (mySet.find(5) != mySet.end()) {
        std::cout << "5 存在于集合中" << std::endl;
    } else {
        std::cout << "5 不存在于集合中" << std::endl;
    }

    return 0;
}
  1. std::unordered_set
    • std::unordered_set 是基于哈希表实现的无序集合。它的元素没有特定的顺序,并且不允许重复元素。
    • 插入、删除、查找操作的平均时间复杂度是 O(1),但在最坏情况下可能会是 O(n),其中 n 是集合中元素的数量。
    • std::unordered_set 的元素是不可变的,一旦插入到集合中就不能修改。
    • 需要包含头文件 <unordered_set>
cpp 复制代码
#include <iostream>
#include <unordered_set>

int main() {
    std::unordered_set<int> myUnorderedSet;

    // 插入元素
    myUnorderedSet.insert(10);
    myUnorderedSet.insert(5);
    myUnorderedSet.insert(15);
    myUnorderedSet.insert(5); // 不会被插入,因为集合中已经存在相同的元素

    // 遍历集合
    for (int num : myUnorderedSet) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    // 删除元素
    myUnorderedSet.erase(10);

    // 查找元素
    if (myUnorderedSet.find(5) != myUnorderedSet.end()) {
        std::cout << "5 存在于集合中" << std::endl;
    } else {
        std::cout << "5 不存在于集合中" << std::endl;
    }

    return 0;
}

这就是C++中集合的简要介绍。根据你的需求和性能要求,你可以选择使用有序集合 std::set 或无序集合 std::unordered_set

相关推荐
辰尘_星启7 分钟前
『CMake』关于使用CMake构建项目时的现代/传统指令
c++·架构·系统·cmake·项目·构建
AA陈超32 分钟前
虚幻引擎5 GAS开发俯视角RPG游戏 P06-13 属性菜单 - 边框值
c++·游戏·ue5·游戏引擎·虚幻
蒙娜丽宁42 分钟前
Rust 性能优化指南:内存管理、并发调优与基准测试案例
开发语言·性能优化·rust
豐儀麟阁贵1 小时前
5.2 类
java·开发语言
九皇叔叔1 小时前
Java循环结构全解析:从基础用法到性能优化(含经典案例)
java·开发语言·python
姝孟1 小时前
C++学习——类与对象详细知识点总结
c++·笔记·学习
JanelSirry1 小时前
如何查看java死锁?具体怎么做,怎么避免
java·开发语言
小龙报2 小时前
《算法通关指南之C++编程篇(5)----- 条件判断与循环(下)》
c语言·开发语言·c++·算法·visualstudio·学习方法·visual studio
郝学胜-神的一滴2 小时前
C++ STL(标准模板库)深度解析:从基础到实践
linux·服务器·开发语言·c++·算法
LL_break2 小时前
线程3 JavaEE(阻塞队列,线程池)
java·开发语言·java-ee·线程·线程池·阻塞队列