前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++ STL容器之set容器快速入门

C++ STL容器之set容器快速入门

作者头像
可定
发布2020-04-20 15:00:07
1.5K0
发布2020-04-20 15:00:07
举报
文章被收录于专栏:细嗅蔷薇细嗅蔷薇

set是内部自动有序且不含重复元素的容器。

使用vector需于代码头部添加#include<set>,并且随后加上一句:using namespace std;即可。

set的定义

set<type> name;

其中type可为任何基本类型(如int等)、结构体和STL标准容器。

注意:(1)若type也是STL容器(STL容器嵌套),则需要在>>后加上空格(C++11之前标准的编译会将其视为移位操作)。即set<set<int>> name;。此时可把vector理解成两个维度都可变的二维数组理解。

set数组的定义

set<int> st[100];

这样st0到st100中每一个set都是一个set容器。

set<set<int>> name;不同的是:这种数组是一维长度为100,另一维长度可变的二维数组。

set容器内元素的访问

和vector容器不同的是,set容器仅能通过迭代器(类似指针)访问

定义:set<typename>::iterator it;

代码:

代码语言:javascript
复制
#include<stdio.h>
#include<set>
using namespace std;
int main(){
    set<int> st;
    //插入元素
    st.insert(3);//insert(x)将x插入set中,并自动去重,时间复杂度O(logN)
    st.insert(5);
    st.insert(2);
    st.insert(3);
    st.insert(4);
    //st.begin()为取st的首元素地址,而it指向此首元素地址
    //遍历元素
    for(set<int>::iterator it1 = st.begin(); it != st.end(); it++){
        //set的迭代器不支持it < vi.end(),因此使用it != vi.end()
        //迭代器it还支持自加和自减各两种操作
        //end()取尾元素地址的下一个地址,即左闭右开
        //end()作为迭代器末尾标志,不存储任何元素
        printf("%d ",*it);
    }
    //查找元素
    set<int>::iterator it2 = st.find(2);
    printf("%d ",*it);//输出2,find(value)返回对应值为value的迭代器,时间复杂度为O(logN)
    printf("%d\n",st.size());  //计算st的长度,输出4,时间复杂度为O(1)
    vi.pop_back();  //删除vi的尾元素5,时间复杂度为O(1)
    //删除单个元素
    //st.erase(vi.begin()+3); 是错误的
    st.erase(st.find(5)); //输出2、3、4,时间复杂度为O(logN)
    //删除一个区间内的所有元素
    set<int>::iterator it3 = st.find(2);
    st.erase(it3, st.end());//删除st[1]、st[2],也就是3和4,即删除[it3,st.end()),时间复杂度为O(st.end()-it3)
    //erase(first, last)删除[first,last),时间复杂度为O(last-first)
    vi.clear();//清空vector中的所有元素,,时间复杂度为O(N)
}

常见用途

自动去重并按升序排序

碰到需要去重却不方便开数组的情况,可以尝试用set解决。

延伸

因为set中元素是唯一的

因此需要处理不唯一元素的情况,可使用multiset

C++11标准中还有unordered_set,以散列替代set内部的红黑树,使其可以用来处理只去重不排序的需求,速度比set快得多。

版权所有:可定博客 © WNAG.COM.CN

本文标题:《C++ STL容器之set容器快速入门》

本文链接:https://cloud.tencent.com/developer/article/1616894

特别声明:除特别标注,本站文章均为原创,本站文章原则上禁止转载,如确实要转载,请电联:wangyeuuu@qq.com,尊重他人劳动成果,谢过~

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-02-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • set的定义
  • set数组的定义
  • set容器内元素的访问
    • 和vector容器不同的是,set容器仅能通过迭代器(类似指针)访问
    • 常见用途
      • 自动去重并按升序排序
      • 延伸
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档