0

0

C++如何使用set和unordered_set_C++集合容器区别与用法示例

穿越時空

穿越時空

发布时间:2025-11-14 16:23:29

|

496人浏览过

|

来源于php中文网

原创

set基于红黑树实现,元素有序,操作复杂度O(log n);unordered_set基于哈希表,无序但平均O(1),需根据是否需要排序选择。

c++如何使用set和unordered_set_c++集合容器区别与用法示例

在C++中,setunordered_set 都是标准模板库(STL)提供的关联容器,用于存储唯一的元素。它们的核心功能相似,但在底层实现、性能特征和使用场景上有明显区别

set 与 unordered_set 的主要区别

set 基于红黑树(一种自平衡二叉搜索树)实现,元素自动按升序排列。插入、删除和查找的时间复杂度为 O(log n)。

unordered_set 基于哈希表实现,元素无固定顺序。理想情况下插入、删除和查找操作接近 O(1),最坏情况可能退化到 O(n)。

选择依据:

立即学习C++免费学习笔记(深入)”;

ProfilePicture.AI
ProfilePicture.AI

在线创建自定义头像的工具

下载
  • 需要有序遍历 → 使用 set
  • 追求最快平均查找速度且不需要排序 → 使用 unordered_set
  • 自定义类型需提供比较函数(set)或哈希函数(unordered_set)

set 使用示例

set 会自动对元素进行排序,并保证唯一性。

#include iostream>
#include
using namespace std;

int main() {
    set s;
    s.insert(5);
    s.insert(1);
    s.insert(3);
    s.insert(5); // 重复元素不会被插入

    cout     for (int x : s) {
        cout     }
    cout
    if (s.find(3) != s.end()) {
        cout     }

    s.erase(1);
    cout     for (int x : s) cout     cout
    return 0;
}

unordered_set 使用示例

unordered_set 不保证顺序,但通常具有更快的访问速度。

#include stream>
#include
using namespace std;

int main() {
    unordered_set us;
    us.insert(5);
    us.insert(1);
    us.insert(3);
    us.insert(5); // 重复,不插入

    cout     for (int x : us) {
        cout     }
    cout
    if (us.count(3)) {
        cout     }

    us.erase(1);
    cout
    return 0;
}

自定义类型的支持

若要在 set 中使用自定义类型,需提供比较函数;对于 unordered_set,需提供哈希函数。

例如定义一个结构体 Person:

struct Person {
    string name;
    int age;
    bool operator==(const Person& p) const {
        return name == p.name && age == p.age;
    }
};

// set 需要小于比较
struct ComparePerson {
    bool operator()(const Person& a, const Person& b) const {
        if (a.name != b.name) return a.name         return a.age     }
};

// unordered_set 需要哈希特化
struct HashPerson {
    size_t operator()(const Person& p) const {
        return hash{}(p.name) ^ (hash{}(p.age)     }
};

// 使用方式:
set people_set;
unordered_set people_unordered;
基本上就这些。根据是否需要有序和性能要求来选择合适的容器。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

713

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.11.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

186

2025.07.04

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

186

2025.07.04

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号