set
1.set
set
set本质是一种红黑树。
使用
- 头文件
#include<set>
- 各功能
set<int > x;//建立一个名为x。元素类型为int的集合。
x.insert(a);//在集合中插入一个元素a,如果元素已有则什么都不干。
x.erase(a);//在集合中删除元素a。如果这个数没有则什么都不干。
x.erase(it);//删除集合中地址为it的元素.
x.end();//返回集合中最后一个元素的下一个元素的地址,一般很少直接使用,通常配合其他方法进行比较.
x.find(a)//查询a在集合中的地址,如果这个数不存在,则返回x.end().
x.lower_bound(a);//查询不小于x的最小的数在集合中的地址,如果这个数不存在,则返回x.end().
x.upper_bound(a);//查询大于x的最小数在集合的地址中的地址,如果此数不存在,则返回x.end()。
x.empty();//如果集合事空则返回1否则返回0
x.size();//返回集合中元素的个数。
- 注意事项
上文提到的地址实际是对应元素的迭代器。lower_bound返回的迭代器,可以用++找到后继元素的迭代器,也可以用--找到前继元素的迭代器,
如果已经是begin()则不能--,如果是end()则不能++。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?