热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C++中的STL基础复习——unordered_set和set

文章目录STL——unordered_setSTL——set关于这个STL(StandardTemplateLibrary)标准模板库STL——unor

文章目录

    • STL——unordered_set
    • STL——set
    • 关于这个STL(Standard Template Library)标准模板库


STL——unordered_set


  1. unordered_set基于哈希表,是无序的,是一个无序的容器
  2. 头文件

#include

  1. 定义以及常用的操作
    定义:

unordered_set<int> set;

  1. 迭代器操作&#xff1a;
    begin返回unordered_set第一个元素的迭代器
    end返回unordered_set最后一个元素下一个位置的迭代器

  2. 常见操作&#xff1a;
    bool empty() const检测unordered_set是否为空
    insert向容器中插入键值对
    erase删除容器中的键值对
    iterator find(const key_type& k)返回k在哈希桶中的位置
    size_t count(const key_type& k)返回哈希桶中关键码为k的键值对的个数
    size_t size() const获取unordered_set的有效元素个数

比如这里的m其实就是我定义的一个unordered_set&#xff0c;它里边的内容如下&#xff1a;

vector<string> wordDict(2);
wordDict[0] &#61; "apple";
wordDict[1] &#61; "pen";
unordered_set<string> m(wordDict.begin(), wordDict.end());//定义容器m里装着字典里的内容

键为0时值为apple&#xff1b;键为1时值为pen。
在这里插入图片描述
6. 一些常用操作的例子&#xff1a;

//定义unordered_set
unordered_set<int> set;
//向容器里插入值
for (int i&#61;0; i<list.size(); i&#43;&#43;)
{set.insert(list[i]);
}
//遍历着输出无序容器里的值
for (unordered_set<int>::iterator i &#61; set.begin(); i !&#61; set.end(); i&#43;&#43;)
{cout << *i << endl;
}
//找出容器里第39个位置的值
cout << " find 39: " << *set.find(39) << endl;
//统计容器里值为5的个数
cout << "count 14:" << set.count(5) << endl;

STL——set


  1. set是STL中的标准关联容器
    set实现了红黑树的平衡二叉检索树的数据结构&#xff0c;插入元素时&#xff0c;它会自动调整二叉树的排列&#xff0c;把元素放到适当的位置&#xff0c;以保证每个子树根节点键值大于左子树所有节点的键值&#xff0c;小于右子树所有节点的键值&#xff1b;另外&#xff0c;还得保证根节点左子树的高度与右子树高度相等。
    作为一个容器也是用来存储同一数据类型的数据类型&#xff0c;并且能从一个数据集合中取出数据&#xff0c;在set中每个元素的值都唯一&#xff0c;而且系统能根据元素的值自动进行排序。应该注意的是set中数元素的值不能直接被改变。
    跟unordered_set也太像了。
  2. 头文件

#include

  1. 定义以及常用的操作
    定义&#xff1a;

set<int> s;

  1. 常用操作&#xff1a;

begin()    ,返回set容器的第一个元素

end()      ,返回set容器的最后一个元素

clear()    ,删除set容器中的所有的元素

empty()    ,判断set容器是否为空

max_size()   ,返回set容器可能包含的元素最大个数

size()      ,返回当前set容器中的元素个数

count() 用来查找set中某个某个键值出现的次数。这个函数在set并不是很实用&#xff0c;因为一个键值在set只可能出现0或1次&#xff0c;这样就变成了 判断某一键值是否在set出现过了。

关于这个STL&#xff08;Standard Template Library&#xff09;标准模板库


  1. 这个库里边封装了许多复杂的数据结构算法和大量常用的数据结构操作。vector封装数组&#xff0c;list封装了链表&#xff0c;map和set封装了二叉树等&#xff0c;在封装这些数据结构的时候&#xff0c;STL按照程序员的使用习惯&#xff0c;以成员函数方式提供的常用操作&#xff0c;如&#xff1a;插入、排序、删除、查找等。让用户在STL使用过程中&#xff0c;并不会感到陌生。

  2. 其实也就是存了很多常用不常用的已经造好的轮子

  3. 从逻辑层次来看&#xff0c;在STL中体现了泛型化程序设计的思想&#xff08;generic programming&#xff09;&#xff0c;引入了诸多新的名词&#xff0c;比如像需求&#xff08;requirements&#xff09;&#xff0c;概念&#xff08;concept&#xff09;&#xff0c;模型&#xff08;model&#xff09;&#xff0c;容器&#xff08;container&#xff09;&#xff0c;算法&#xff08;algorithmn&#xff09;&#xff0c;迭代子&#xff08;iterator&#xff09;等。与OOP&#xff08;object-oriented programming&#xff09;中的多态&#xff08;polymorphism&#xff09;一样&#xff0c;泛型也是一种软件的复用技术

  4. 如果&#xff0c;有的时候&#xff0c;你需要在程序中用到堆、栈、队列、链表等一些基本的算法&#xff0c;而你又实在不想自己去实现数据结构教科书中那些繁琐的算法&#xff0c;那么你就可以考虑使用STL。

  5. 红黑树的底层实现就是set和map。

了解下红黑树&#xff1a;
红黑树在二叉查找树的基础上还必须满足以下着色规则&#xff1a;
每个节点不是红色就是黑色
根节点为黑色
如果节点为红&#xff0c;其子节点必须为黑&#xff08;一条路径上不能出现连续的两个红色节点&#xff09;
任一节点至NULL&#xff08;树尾端&#xff09;的任何路径&#xff0c;所含之黑节点数必须相同

  1. 很常用的有vector&#xff0c;string&#xff0c;stack&#xff0c;queue&#xff0c;set&#xff0c;unordered_set&#xff0c;map等。

推荐阅读
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
author-avatar
宛岸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有