set学习(系统的学习)
set是STL中一种标准关联容器。它底层使用平衡的搜索树——红黑树实现,插入删除操作时仅仅需要指针操作节点即可完成,不涉及到内存移动和拷贝,所以效率比较高。set,顾名思义是“集合”的意思,在set中元素都是唯一的,而且默认情况下会对元素自动进行升序排列,支持集合的交(set_intersection),差(set_difference) 并(set_union),对称差(set_symmetric_difference) 等一些集合上的操作,如果需要集合中的元素允许重复那么可以使用multiset。
下面介绍set的常用操作:
1:注意包含头文件<set>
set只有自加和自减运算!!!
s.begin() 返回set容器的第一个元素的地址
s.end() 返回set容器的最后一个元素之后的地址
s.clear() 删除set容器中的所有的元素
s.empty() 判断set容器是否为空
s.insert() 插入一个元素
s.erase() 删除一个元素
s.size() 返回当前set容器中的元素个数
具体看代码:
#include<iostream>
#include<set>
using namespace std;
int main()
{
set<int> s;//创建一个set对象
for(int i=;i<;i++)
s.insert(i+);//插入三个元素,10 11 12
cout<<*s.begin()<<endl;//输出第一个元素10
cout<<*(--s.end())<<endl;//输出最后一个元素
s.erase(s.begin());//删除第一个元素
cout<<*s.begin()<<endl;//第一个元素变为11
cout<<s.size()<<endl;//答案为2
s.clear();//清空所有元素
cout<<s.size()<<endl;//输出为0
return ;
}
迭代器的使用:
#include<iostream>
#include<set>
using namespace std;
int main()
{
set<int> s;//创建一个set对象
for(int i=;i<;i++)
s.insert(i+);//插入三个元素,10 11 12
set<int>::iterator it;//创建一个迭代器
for(it=s.begin();it!=s.end();it++)//用迭代器进行遍历
cout<<*it<<" ";
cout<<endl;
it=s.begin();
it++;
s.erase(it);//用迭代器进行删除操作
for(it=s.begin();it!=s.end();it++)//用迭代器进行遍历
cout<<*it<<" ";
cout<<endl;
return ;
}
修改:不能修改容器内数据,所以只能删除某元素再插入要修改的数值
查找:s.find()
如果容器内不存在该元素,返回值等于s.end();
#include<iostream>
#include<set>
using namespace std;
int main()
{
set<int> s;//创建一个set对象
for(int i=;i<;i++)
s.insert(i+);//插入三个元素,10 11 12
set<int>::iterator it;//创建一个迭代器
for(it=s.begin();it!=s.end();it++)//用迭代器进行遍历
cout<<*it<<" ";
cout<<endl;
if(s.find()!=s.end()) cout<<"yes"<<endl;
return ;
}
set的其它常用操作:
s.lower_bound() 返回第一个大于或等于给定关键值的元素
s.upper_bound() 返回第一个大于给定关键值的元素
s.equal_range() 返回一对定位器,分别表示 第一个大于或等于给定关键值的元素 和 第一个大于给定关键值
的元素,这个返回值是一个pair类型,如果这一对定位器中哪个返回失败,就会等于
s.end()
#include<iostream>
#include<set>
using namespace std;
int main()
{
set<int> s;//创建一个set对象
for(int i=;i<;i++)
s.insert(i+);//插入三个元素,10 11 12
cout<<*s.lower_bound()<<endl;//输出10
cout<<*s.upper_bound()<<endl;//输出11
cout<<*s.equal_range().first<<endl;//
cout<<*s.equal_range().second<<endl;//
return ;
}
如果要把set定义为降序:可以如下定义:
#include<iostream>
#include<set>
using namespace std;
int main()
{
set<int,greater<int> >s;
for(int i=;i<;i++)
s.insert(i+);
set<int>::iterator it;
//降序输出
for(it=s.begin();it!=s.end();it++) cout<<*it<<endl;
return ;
}
set学习(系统的学习)的更多相关文章
- 4 WPF学习---系统的学习XAML语法
转载:http://blog.csdn.net/fwj380891124/article/details/8093001 1,XAML文档的树形结构: UI在用户眼里面是个平面结构.如下图所示,在用户 ...
- NNVM打造模块化深度学习系统(转)
[摘录理由]: 之所以摘录本文,主要原因是:该文配有开源代码(https://github.com/dmlc/nnvm):读者能够直接体会文中所述的意义,便于立刻展开研究. MXNet专栏 :NNVM ...
- SpeeDO —— 并行深度学习系统
SpeeDO —— 并行深度学习系统 摘要: 最近,AlphaGo又带起了一波深度学习的热潮.深度学习在很多领域都大幅提高了模型的精度,使得很多以前在实验室中的技术得以运用到日常的生活之中.然而, ...
- node+vue进阶【课程学习系统项目实战详细讲解】打通前后端全栈开发(1):创建项目,完成登录功能
第一章 建议学习时间8小时·分两次学习 总项目预计10章 学习方式:详细阅读,并手动实现相关代码(如果没有node和vue基础,请学习前面的vue和node基础博客[共10章]) 视频教程地 ...
- Google会思考的深度学习系统
上周五在旧金山举行的机器学习会议上,Google软件工程师Quoc V. Le讲解了Google的"深度学习"系统是如何运作的. "深度学习"需要用到大型计算机 ...
- 如何系统的学习Java
初学者记住一点,学习Java一定是连续性的且循序渐进的“系统化”学习,首先我给你提供一个优秀Java工程师的学习路线. web前端方面:html.css,Java.jQuery.xml解析.Boots ...
- 一点点linux系统的学习心得
我相信你正在阅读本文的时候,可能是因为你渴望学习Linux技术.我想分享一下过去两年中我自己的一些学习经历,希望你能更顺利地成为Linuxer. 两年前在Linux系统的运行和维护方面找到了一份工作( ...
- Unity3d-Particle System 5.x系统的学习(四)
Unity3d-Particle System 5.x系统的学习(四) 今天,我们来聊聊unity5.x的粒子系统和unity4.x粒子系统的区别. 我大致看了下,区别还是蛮多的,但是总体的粒子制作思 ...
- 安装虚拟机和Linux系统的学习
安装虚拟机和Linux系统的学习(随笔3) 1.安装虚拟机 首先我按着老师给的链接上的步骤一步一步安装VirtualBox,进行得十分顺利. 接着则是在虚拟机上安装Ubuntu. 然而安装完成以后按要 ...
随机推荐
- 第二周个人作业:WordCount
github地址 https://github.com/lzwk/WordCount PSP表格 PSP2.1 PSP阶段 预估耗时(分钟) 实际耗时(分钟) Planning 计划 20 40 · ...
- boost库thread.hpp编译警告honored已修复
请浏览:https://svn.boost.org/trac/boost/ticket/7874 #7874: compile warning: thread.hpp:342: warning: ty ...
- TimerTask
当TimerTask实例通过schedule方法使用之后,不能通过schedule方法调用第二次,如果重复使用就会抛异常TimerTask is scheduled already. 当你重新想利用这 ...
- MyEclipse 基本使用(三)
视频地址如下 https://pan.baidu.com/s/1boxK4LT#list/path=%2F%E5%8A%A8%E5%8A%9B%E8%8A%82%E7%82%B9%E8%A7%86%E ...
- 单击GridView控件,高亮单击所在的记录行
看过下面博文的网友,也许都会觉得有点遗憾,就是很难知道自己点击的是哪一记录行.http://www.cnblogs.com/insus/p/3211017.html 针对这个问题Insus.NET再对 ...
- 割点(Tarjan算法)【转载】
本文转自:www.cnblogs.com/collectionne/p/6847240.html 供大家学习 前言:之前翻译过一篇英文的关于割点的文章(英文原文.翻译),但是自己还有一些不明白的地方, ...
- Locust学习总结分享
简介: Locust是一个用于可扩展的,分布式的,性能测试的,开源的,用Python编写框架/工具,它非常容易使用,也非常好学.它的主要思想就是模拟一群用户将访问你的网站.每个用户的行为由你编写的py ...
- Django之后台管理二
前面讲到admin界面用户的注册以及修改,如果我们注册的用户密码忘记了该怎么办呢 在终端输入如下的命令进行重置 D:\django_test2>python manage.py shell Py ...
- git pull 命令
作用:取回远程主机某个分支的更新,再与本地的指定分支合并 格式:git pull <远程主机名> <远程分支名>:<本地分支名> 1. 如果与当前分支合并,则可省 ...
- loj #2006. 「SCOI2015」小凸玩矩阵
#2006. 「SCOI2015」小凸玩矩阵 题目描述 小凸和小方是好朋友,小方给小凸一个 N×M N \times MN×M(N≤M N \leq MN≤M)的矩阵 A AA,要求小凸从其中选出 ...