set用法笔记

1. set是一个内部自动递增排序且自动去除重复元素的容器。

    unordered_set   只去重不排序,速度更快

2.头文件 #include<set>,using namespace std;

3. set<int> s; set<char> s; set<double> s;

    set<node> s;

    set<int> s[100];//有100个set;vector<int> v[100];为100个vector

4.只能通过迭代器访问

for( set<int>::iterator it = s.begin(); it != s.end(); it++ )
{
    printf("%d",*it);
}

5.

#include<cstdio>
#include<set>
using namespace std;
int main(){
//创建
    set<int> s;
//插入,递增排序并去重,时间复杂度O(logN),N为元素个数
    s.insert(100);
    s.insert(200);
    s.insert(300);
    s.insert(600);
    s.insert(50);
//查找,返回迭代器,时间复杂度O(logN),N为元素个数
    set<int>::iterator it=s.find(100);//find返回迭代器
//删除
    s.erase(it);//此处两行等价于s.erase(s.find(100));O(1)
    s.erase(300);//erase参数可为迭代器也可为值,O(logN)
    s.erase(s.find(200),s.end);//删除一段,erase(first,last),O(last-first),迭代器
//O(1)
    int a = s.size();
//O(N)
    s.clear();
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值