C++ STL, set用法。

insert()    ,插入一个元素

clear()          ,删除set容器中的所有的元素

empty()    ,判断set容器是否为空

size()      ,返回当前set容器中的元素个数

count()    ,用来查找set中某个键值出现次数。

find()        ,返回给定值值得定位器,如果没找到则返回end()

        查找数据,find。返回值是找到的情况的迭代器,如果没有找到,
         迭代器只想end,如果找到,为找到的数据,所以这里一定要先
        判断一下是否找到数据了。

erase(iterator)  ,删除定位器iterator指向的值

 1 #include"iostream"
 2 #include"set"
 3 using namespace std;
 4 int main(){
 5     set<int> s;
 6     set<int>::iterator it;  //创建一个他对应的迭代器
 7     for(int i=0;i<10;i++){
 8         s.insert(i);
 9     }
10     if(s.empty())//如果为空返回true
11         cout<<"s为空"<<endl;
12     else
13         cout<<"s不为空"<<endl;
14     cout<<"set容器元素个数为"<<s.size()    <<endl;
15     cout<<"1出现的次数"<<s.count(1)<<endl;
16     cout<<"10出现的次数"<<s.count(10)<<endl;
17     s.erase(5);//删除5
18     cout<<"5出现的次数"<<s.count(5)<<endl;
19     it=s.find(4);
20     if(it!=s.end())
21         cout<<*it<<endl;
22     return 0;
23 }
时间: 2024-10-07 18:14:44

C++ STL, set用法。的相关文章

STL容器用法速查表:list,vector,stack,queue,deque,priority_queue,set,map

STL容器用法速查表:list,vector,stack,queue,deque,priority_queue,set,map   list vector deque stack queue priority_queue set [unordered_set] map [unordered_map] multimap [unordered_multimap]     contiguous storage double-ended queue LIFO FIFO 1st is greatest  

STL set 用法

c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许.1) 不能直接改变元素值,因为那样会打乱原... c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许. 1) 不能直接改变元素值,因为那样会打乱原本正确的顺序,

记一些stl的用法(持续更新)

有些stl不常用真的会忘qwq,不如在这里记下来,以后常来看看 C++中substr函数的用法 1 #include<string> 2 #include<iostream> 3 using namespace std; 4 5 void main() 6 { 7 string s("12345asdf"); 8 string a=s.substr(0,5); 9 cout<<a<<endl; 10 } (以上转自:https://www

STL常见用法

1.选择C++刷算法的理由 1.C++速度快(C不是更快么,java太慢了) 2.C++有STL(什么是STL)--使用很方便的类库 3.如何使用STL进行高效刷算法 4.好处:刷算法,学习成本极低 5.如何从C到C++(仅基础语法到刷算法程度) 俗话说:磨刀不误砍柴工 不会c++仍然可以做,但是效率低 2.输入输出 C++保留了C的scanf和printf,增加了额外的cin与cout 例子 2.1.C程序中输入输出 int a; scanf("%d",&a); printf

STL vector用法介绍

介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通过阅读这篇文章读者应该能够有效地使用vector容器,而且应该不会再去使用C类型的动态数组了.   Vector总览 vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象

STL vector用法介绍(转)

介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通过阅读这篇文章读者应该能够有效地使用vector容器,而且应该不会再去使用C类型的动态数组了.   Vector总览 vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象

STL --&gt; list用法

List介绍 Lists将元素按顺序储存在链表中. 与 向量(vectors)相比, 它允许快速的插入和删除,但是随机访问却比较慢. assign()                                   给list赋值  back()                                     返回最后一个元素  begin() 返回指向第一个元素的迭代器  clear() 删除所有元素  empty() 如果list是空的则返回true  end()   返回末尾的

STL:map用法总结

一:介绍 map是STL的关联式容器,以key-value的形式存储,以红黑树(平衡二叉查找树)作为底层数据结构,对数据有自动排序的功能.命名空间为std,所属头文件<map> 二:常用操作 容量:a.map中实际数据的数据:map.size()b.map中最大数据的数量:map.max_size()c.判断容器是否为空:map.empty() 修改:a.插入数据:map.insert()b.清空map元素:map.clear()c.删除指定元素:map.erase(it) 迭代器:a.map

STL 优先队列 用法

今天做题用到了优先队列 对它的用法还不是很熟悉 现在整理一下. 需要的库 #include<queue> using namespace std; 不过我都用bits/stdc++.h... 定义 priority_queue<Type, Container, Functional> Type是数据的类型 比如int啊char啊之类的 Container是容器类型默认是vector Functional是比较的方式  比如greater<int>   less<i

stl list用法小计

list容器介绍 相对于vector容器的连续线性空间,list是一个双向链表,它有一个重要性质:插入操作和删除操作都不会造成原有的list迭代器失效,每次插入或删除一个元素就配置或释放一个元素空间.也就是说,对于任何位置的元素插入或删除,list永远是常数时间. (1)    构造函数 list<Elem> c:创建一个空的list list<Elem> c1(c2):复制另一个同类型元素的list list<Elem>c(n):创建n个元素的list,每个元素值由默