【C++】关联式容器——map&set的使用(中)

简介: 【C++】关联式容器——map&set的使用(中)

3. 迭代器

2bdb5fda44346bb71ad8a249cdb3f930.png

set迭代器的使用与其他容器的迭代器一样

void Test2()
{
    vector<int> v = {1,3,5,2,6,3,5,1};
    set<int> s(v.begin(), v.end());//使用set存放之后可以去重
    set<int>::iterator it1 = s.begin();
    cout << "正向迭代器:";
    while(it1 != s.end())
    {
        cout <<*it1 << " ";
        ++it1;
    }
    cout << endl;
    set<int>::reverse_iterator it2 = s.rbegin();
    cout << "反向迭代器:";
    while (it2 != s.rend())
    {
        cout << *it2 << " ";
        ++it2;
    }
    cout << endl;
}


6d4f249f7e4dab25e25362aa503499ff.png

4.容量相关操作

函数原型 说明
bool empty() const; 判断set是否为空,如果为空返回true,否则返回flase
size_t size() const; 返回容器的数据个数,类型为size_t(unsigned int)
size_t max_size() const; 返回容器中最多能够存放的数据个数


5.modify

1.insert

向set中插入一个对象,并且能够保持结构不变,依然符合平衡搜索树

79a98e8ac9a79c9d7638d7606a67fab7.png

这里注意一下:第一个插入返回的是一个pair类型的对象,其中pair的第一个成员是一个迭代器,其指向的是插入的元素在set中的位置,第二个成员是bool类型,如果成功插入了数据就返回true,若set中已经存在这个数据,就会插入失败,其中的值就是false。


所以这里insert能够做到两个功能:查找和插入。


2.erase

在set中删除一个数据,并且结构保持不变

b8ad5df68d355e84db2a6ed011191d54.png

void Test3()
{
    vector<int> v = {1,3,5,2,6,3,5,1};
    set<int> s(v.begin(), v.end());//使用set存放之后可以去重
    cout << "before insert:";
    auto it1 = s.begin();
    while(it1 != s.end())
    {
        cout <<*it1 << " ";
        ++it1;
    }
    cout << endl;
    //insert
    auto a1 = s.insert(4);
    auto a2 = s.insert(4);
    cout << "after insert:";
    it1 = s.begin();
    while(it1 != s.end())
    {
        cout <<*it1 << " ";
        ++it1;
    }
    cout << endl;
    cout << "a1:" << *(a1.first) << ":" << a1.second << endl;
    cout << "a2:" << *(a2.first) << ":" << a2.second << endl;
    cout << "---------------------------" << endl;
    s.erase(4);
    cout << "after erase";
    it1 = s.begin();
    while(it1 != s.end())
    {
        cout <<*it1 << " ";
        ++it1;
    }
    cout << endl;
}

image-20230513123204561.png

3.swap

交换两个set对象,效率比算法库里实现的高

a099793c4dc96a3b92e7d317be79cd1d.png


4.clear

清除set对象中所有数据,但是不删除set对象

b69cf3b6494468ae858ad67af2c687d8.png


6.其他操作接口

1.find

查找set中某个元素,并返回迭代器,如果不存在,就返回end()。

e2c45dc1cff6f32a2af9b37086fb8f21.png

2.lower_bound

以传入的值为下限,返回一个迭代器

ab656e7ae54d1e0d83e8542dc8f69c4a.png

3.upper_bound

以传入的值为上限,返回一个迭代器

528f381b74d1177411fe1c6579a37915.png

void Test4()
{
    set<int> s;
    for(int i = 1; i < 10; ++i)
        s.insert(10 * i);
    auto it = s.find(30);
    if(it != s.end())
        s.erase(it);
    for(const auto& e : s)
    {
        cout << e << " ";
    }
    cout << endl;
    auto it1 = s.lower_bound(40);
    auto it2 = s.upper_bound(70);//注意,这里返回的是70的下一个位置
    s.erase(it1,it2);//这里的删除的迭代器区间是前闭后开的
    for(const auto& e : s)
    {
        cout << e << " ";
    }
    cout << endl;
}

除了set之外,在set头文件中还包含了一个容器:multisetmultiset使用文档

multiset与set极其相似,唯一的不同点就是multiset支持在内部插入重复的数据。

void Test5()
{
    vector<int> v = {1,3,5,2,6,3,5,1};
    set<int> s(v.begin(), v.end());
    multiset<int> ms(v.begin(), v.end());
    cout << "     set:";
    for(const auto& e : s)
    {
        cout << e << " ";
    }
    cout << endl;
    cout << "multiset:";
    for(const auto& e : ms)
    {
        cout << e << " ";
    }
    cout << endl;
}


这里补充一个在set里面没有介绍的接口:count:计算val在multiset中的个数,也可以用来判断set中是否存在该元素。

f611af5239fab565357014f7241c8182.png

相关文章
|
1天前
|
存储 安全 Java
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
|
2天前
|
存储 编译器 C++
C++:map&set 对红黑树的封装
C++:map&set 对红黑树的封装
8 1
|
2天前
|
存储
Map与Set的经典OJ题
Map与Set的经典OJ题
9 3
|
2天前
|
存储 自然语言处理 容器
Map与Set
Map与Set
9 3
|
2天前
|
存储 C++ 容器
C++:STL - set & map
C++:STL - set & map
11 4
|
2天前
|
调度 C++ 容器
【C++】手搓 list 容器
本文我们实现了STL库中重要的list 的模拟实现,其中最重要莫过于迭代器的封装类的书写,这是前所未有的操作(对于我来说,我是第一次使用这种结构)。通过list 的模拟实现也帮我们巩固了类与对象的知识,也强化了指针操作的思路。欢迎大家讨论分析。
12 1
|
5天前
|
存储 设计模式 算法
【C++/STL】stack和queue(容器适配器、优先队列、双端队列)
【C++/STL】stack和queue(容器适配器、优先队列、双端队列)
11 1
|
5天前
|
存储 C++ 容器
[数据结构]-map和set
[数据结构]-map和set
|
10天前
|
存储 前端开发 索引
【Web 前端】ES6中,Set和Map的区别 ?
【5月更文挑战第1天】【Web 前端】ES6中,Set和Map的区别 ?
|
1天前
|
NoSQL Redis Docker
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
10 0