STL初步学习(set)
2.set
set可以看作一个集合,可以实现自动排序(升序)和去重
在许多题目中,都可以使用这个模板库,减少很多操作,例如P1923 第k小数,当然,这道题有很多奇奇怪怪的做法,分值都不同,之后会讲解
set的定义
#include<set> //头文件
using namespace std; //这条必须加
set<typename> a; //同vector一样,这里可以用不同的数据类型
set<typename> b[SIZE]; //定义set数组,有点类似vector的二维数组
//b[0]~b[SIZE-1]都为set容器
其实很多与vector相似的地方,其他的许多STL容器感觉也都差不多。接下来是set的遍历,和vector不一样的是,这里只能用迭代器遍历,不能使用数组下标
set<typename> name;
for(set<typename>::iterator it=name.begin();it!=name.end();it++){
cout<<*it<<" ";
} //只能使用迭代器访问
然后是涉及到的一些函数(都只介绍常用的);
①insert( ) insert(x),将x放入集合中,并自动去重和升序排序,时间复杂度为O(logN),N为元素个数
②find( ) find(x)返回set中对应值为x的迭代器,时间复杂度为O(logN)
③erase( ) 时间复杂度为O(1)
用法(1)erase(x)删除对应值为x的元素;用法(2),同find( )一起使用,erase(find(x)),用find找到x的迭代器,然后删除。
④同vector一样,可以使用clear( ),时间复杂度为O(N);size( ),时间复杂度为O(1)
另外,set和map都是用红黑树来实现
例题
P1932 第k小数
(一) 非常简单暴力的思路,直接用sort快排,输出,60分,超时
(二)学了set之后,因为set自动排序,就选用了set,至于找到第k个数,可以直接用迭代器初始值为a.begin( ),然后进行k次it++。结果只有20分,是因为set要去重,导致处理之后数据出错
set<int>::iterator it = a.begin( );
while(--k)it++;
cout << *it;
(三)在查询了一些资料之后,发现有一个东西叫做multiset,和set的许多用法相同,但是他处理数据是不会进行去重的,只会升序排列。但是也只有60分,依然改变不了他超时的事实
multiset<int>::iterator it = a.begin( );
while(k--)it++;
cout << *(it);
(四)无奈之下,通过题解,发现STL还有一个叫做nth_element的东西,nth_element(a,a+k,a+n),三个参数分别指(数组名,第k个,数组长度)当时直接给我看懵了,100分做法
for(int i=1; i<=n; i++)
scanf("%d",&a[i]);
nth_element(a+1,a+k+1,a+1+n);
printf("%d",a[k+1]);
当然还可以用二分做,但这里主要是讲set,就不阐述了,通过这道题,可以加深对set的一些理解,例如做题时的选择,是否考虑去重的问题,当然还有时间复杂度
STL初步学习(set)的更多相关文章
- STL初步学习(vector)
前文 初三下学期进入新的学习,对于前两年的学习内容因为各种原因 上课打游戏,睡觉,看视频 已经遗忘,忘记如何使用,算是重新学习一次信息学,希望能尽快将以前的内容弥补上来,争取能在CSP-2020取得一 ...
- STL初步学习(queue,deque)
4.queue queue就是队列,平时用得非常多.栈的操作是只能是先进先出,与栈不同,是先进后出,与之后的deque也有区别.个人感觉手写队列有点麻烦,有什么head和tail什么的,所以说 STL ...
- AcWing STL初步学习
vector, 变长数组,倍增的思想 size() 返回元素个数 empty() 返回是否为空 clear() 清空 front()/back() push_back()/pop_back() beg ...
- STL初步学习(map)
3.map map作为一个映射,有两个参数,第一个参数作为关键值,第二个参数为对应的值,关键值是唯一的 在平时使用的数组中,也有点类似于映射的方法,例如a[10]=1,但其实我们的关键值和对应的值只能 ...
- json2.js的初步学习与了解
json2.js的初步学习与了解,想要学习json的朋友可以参考下. json2.js的初步学习与了解 1.)该js的下载地址是:http://www.json.org/json2.js 2.)在页面 ...
- 老周的ABP框架系列教程 -》 一、框架理论初步学习
老周的ABP框架系列教程 -- 一.框架理论初步学习 1. ABP框架的来源与作用简介 1.1 简介 1.1.1 ABP框架全称为"ASP.NET Boilerplate ...
- 初步学习nodejs,业余用node写个一个自动创建目录和文件的小脚本,希望对需要的人有所帮助
初步学习nodejs,业余用node写个一个自动创建目录和文件的小脚本,希望对需要的人有所帮助,如果有bug或者更好的优化方案,也请批评与指正,谢谢,代码如下: var fs = require('f ...
- EF Codefirst 初步学习(二)—— 程序管理命令 更新数据库
前提:搭建成功codefirst相关代码,参见EF Codefirst 初步学习(一)--设置codefirst开发模式 具体需要注意点如下: 1.确保实体类库程序生成成功 2.确保实体表类库不缺少 ...
- 初步学习python
自计算机诞生以来,也伴随着计算机语言的诞生,现在,全世界的编程语言有600多种,但流行的编程语言也就20多种. Java和C一直占据着前两名.但是近年来伴随着人工智能的发展,Python发展迅猛,以其 ...
随机推荐
- Java实现蓝桥杯算法提高P0102
算法提高 P0102 时间限制:1.0s 内存限制:256.0MB 提交此题 用户输入三个字符,每个字符取值范围是0-9,A-F.然后程序会把这三个字符转化为相应的十六进制整数,并分别以十六进制,十进 ...
- Jmeter之Json提取器详解(史上最全)
参考资料:https://www.bbsmax.com/A/D854lmBw5E/ Jsonpath在线测试:http://jsonpath.com/ 实际工作中用到的一些场景: 提取某个特定的值 提 ...
- CDN HTTPS安全加速基本概念、解决方案及优化实践
大家都知道,HTTP 本身是明文传输的,没有经过任何安全处理,网站HTTPS解决方案通过在HTTP协议之上引入证书服务,完美解决网站的安全问题.本文将为大家介绍阿里云CDN HTTPS安全加速传输的基 ...
- k8s-ephemeral和init容器
截止到目前k8s1.18版本,k8s已经支持四种类型的container:标准容器,sidecar容器,init容器,ephemeral容器. 一:ephemeral容器 1.1.什么是ephemer ...
- 【JAVA习题二十九】809*??=8*??+9*??+1 其中??代表的两位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。
package erase; public class 八九与问好两位数的乘积和 { public static void main(String[] args) { int m,n;//m十位,n个 ...
- Nice Jquery Validator 【从 jQuery Validation 迁移】
1. 初始化表单验证 .validate VS .validator jquery-validation : $("#myform").validate(options) nice ...
- (四)Parameters,简单参数就用这个
Parameters注解在测试方法上指定参数列表,然后在测试方法中声明对应的形参,形参与参数列表一一对应,但名字可以不同,如下所示: public class Test1 { @Parameters( ...
- (五)pom文件详解
<?xml version="1.0" encoding="UTF-8"?> <!--是所有pom.xml的根元素,并且在里面定义了命名空间和 ...
- java中工厂模式
最近在项目中使用了工厂模式来重构下之前的代码,在这里做个小结. 工厂模式最主要的特点是每次新增一个产品的时候,都需要新增一个新的工厂,这样在对于新的产品做扩展的时候,减少对客户端代码的修改. 我在项目 ...
- Android开发Fragment的使用学习
基本概念 Fragment是Android3.0(API11)提出的概念,support-v4库中也开发了一套Fragment API,最低兼容Android 1.6.所以在开发中要注意不要导错包 导 ...