c++set详解

一、c set类

c set类是c++ STL中的一个数据结构,它是一种关联容器,用于存储唯一且有序的元素。它可以采用红黑树、avl树等数据结构实现,其底层的实现与使用者无关。在c set容器中,元素是唯一的,从而可以防止容器中存储的元素出现重复。

c set类模板定义如下:

template<class T, class Compare = less,
class Allocator = allocator > class set;

T:表示set容器中的数据类型,可以是任何数据类型。

Compare:比较函数,也叫做比较对象,对于实现自定义数据类型的c set类,需要传递自定义的比较函数,否则,默认使用std::less函数进行默认排序。

Allocator:内存分配器,用于指定内存的存储位置,可以使用std::allocator类进行默认内存分配。

二、c set up o好噗四姑夫柚子

c set up是指从小到大的排序,而c set o是指从大到小的排序。默认情况下,c set采用从小到大的排序方式。如果用户需要使用从大到小的排序方式,需要通过自定义比较函数来实现。下面是一个从大到小排序的示例:

set<int, greater > mySet;
mySet.insert(1);
mySet.insert(3);
mySet.insert(2);
for (auto i : mySet)
   cout << i << " ";

输出结果为:3 2 1

三、c set 降序

c set容器是由于内部采用红黑树结构实现的,因此它的迭代器是一个双向迭代器,而不是随机访问迭代器。在使用迭代器进行遍历时,可以采取reverse_iterator的方式实现降序,而不需要使用sort等算法手动进行排序。下面是一个示例:

set mySet{ 1,2,3 };
for (auto it = mySet.crbegin(); it != mySet.crend(); it++)
   cout << *it << " ";

输出结果为:3 2 1

四、c set的实现

c set容器是一个基于红黑树实现的关联式容器,它与vector、deque等顺序式容器不同。在c set容器中,元素是唯一的,从而可以防止容器中存储的元素出现重复。红黑树是一种二叉查找树,它必须满足以下性质:

  • 每个节点都是红色或黑色
  • 根节点是黑色
  • 每个叶子节点(NULL节点)是黑色
  • 如果一个节点是红色的,则它的两个子节点都是黑色的
  • 从一个节点到该节点的所有叶子节点的路径上包含相同数目的黑色节点

红黑树的优点在于:

  • 查找和插入操作的时间复杂度O(logN)
  • 插入、删除元素时,保持set有序性
  • 支持自定义比较函数和默认排序

下面是一个c set的简单实现代码:

#include 
#include 
using namespace std;
int main()
{
    set mySet;
    mySet.insert(1);
    mySet.insert(2);
    mySet.insert(3);
    for (auto i : mySet)
        cout << i << " ";
    return 0;
}

五、c set用法

c set容器的用法与vector、deque等容器相似,通过insert和erase等函数来实现对容器中元素的增、删操作,支持随机访问、迭代器遍历等操作。下面是一些常用的c set用法示例:

1、查找元素

set mySet{ 1,2,3 };
if (mySet.find(2) != mySet.end())
    cout << "2 is found" << endl;

2、统计元素出现次数

set mySet{ 1,1,2,3 };
cout << "1 occurred " << mySet.count(1) << " times" << endl;

3、删除元素

set mySet{ 1,2,3,4 };
mySet.erase(2);
for (auto i : mySet)
    cout << i << " ";

输出结果为:1 3 4

六、c setw函数

c setw函数用于控制输出时所占的列数,通常用于表格型的输出。c++设置setw函数的方法如下:

cout << setw(5) << "1";
cout << setw(5) << "2";
cout << setw(5) << "3";

输出结果为:

    1    2    3

七、c set有序

c set容器有序,这意味着元素在插入时会根据元素的值进行排序,因此,c set中的元素是有序的。在c set中,可以通过自定义比较函数来控制元素的排序规则,从而实现多种排序方式。下面是一个根据字符串长度排序的示例:

struct StringLenComp
{
    bool operator()(const string &s1, const string &s2) const
    {
        return s1.size() < s2.size();
    }
};

set mySet{ "aaa", "bb", "ccccc" };
for (auto i : mySet)
    cout << i << " ";

输出结果为:bb aaa ccccc

八、c set的头文件

c set容器是c++ STL中的一种关联式容器,因此其头文件为set.h。但是,在c++标准库中,set容器的头文件为set,并且位于std命名空间之内,因此设置头文件如下:

#include 
using namespace std;

九、set up

set up是指从小到大的排序方式,在c set容器中,默认的排序方式即为set up。下面是一个示例代码:

set mySet;
mySet.insert(1);
mySet.insert(3);
mySet.insert(2);
for (auto i : mySet)
   cout << i << " ";

输出结果为:1 2 3

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/271613.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝的头像小蓝
上一篇 2024-12-16 19:23
下一篇 2024-12-16 19:23

相关推荐

  • Python中set函数的作用

    Python中set函数是一个有用的数据类型,可以被用于许多编程场景中。在这篇文章中,我们将学习Python中set函数的多个方面,从而深入了解这个函数在Python中的用途。 一…

    编程 2025-04-29
  • Python Set元素用法介绍

    Set是Python编程语言中拥有一系列独特属性及特点的数据类型之一。它可以存储无序且唯一的数据元素,这使得Set在数据处理中非常有用。Set能够进行交、并、差集等操作,也可以用于…

    编程 2025-04-29
  • Python set去重保留原顺序

    当一个列表中出现重复的元素时,为了去除这些重复元素可以使用Python提供的集合(set)数据结构,集合可以去除元素的重复出现。然而,这样会导致原有的元素顺序混乱,这时,需要使用一…

    编程 2025-04-27
  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25

发表回复

登录后才能评论