基础数据结构->set&&map
set&&map
BEGIN:惜墨如金
set用法
基本用法
#include<bits/stdc++.h>
using namespace std;
void the_set()
{
int x=404;
set<int>ds;
ds.insert(x);//如果在ds这个set 中无x,则插入;否则啥也不干
ds.erase(x);//如果ds在这个set 中有x,则删除;否则不干
auto it=ds.begin();
ds.erase(it);//删除it指向元素
ds.end();//last+1地址
ds.begin();//
/*int l1=*ds.lower_bound(x);//查询不小于x最小的数在集合中的地址,
//否则返回ds.end()
int l2=*ds.upper_bound(x);//查询大于x最小的数在集合中的地址,
//无则返回ds.end()*/
//以上代码有误
int the_x_number=*ds.upper_bound(x)-*ds.lower_bound(x);
//配合可以求出set中有多少x
ds.size();//
return;//OK
}
int main()
{
the_set();
return 0;
}
例题P5250
【深基17.例5】木材仓库
题目描述
博艾市有一个木材仓库,里面可以存储各种长度的木材,但是保证没有两个木材的长度是相同的。作为仓库负责人,你有时候会进货,有时候会出货,因此需要维护这个库存。有不超过 100000 条的操作:
- 进货,格式
1 Length:在仓库中放入一根长度为 Length(不超过 10⁹) 的木材。如果已经有相同长度的木材那么输出Already Exist。 - 出货,格式
2 Length:从仓库中取出长度为 Length 的木材。如果没有刚好长度的木材,取出仓库中存在的和要求长度最接近的木材。如果有多根木材符合要求,取出比较短的一根。输出取出的木材长度。如果仓库是空的,输出Empty。
输入格式
输出格式
样例 #1
样例输入 #1
7
1 1
1 5
1 3
2 3
2 3
2 3
2 3
样例输出 #1
3
1
5
Empty
思路
用set
这题前面可以用if(!ds.insert(a).second) cout<<"Already Exist"<<endl;一行搞定
后面则用lower_bound求出第一接近靠后值 与 第一接近靠前值比对
code_AC
#include<bits/stdc++.h>
using namespace std;
int ccc;
set<int>ds;
void inc(int a)
{
//int num=*( ds.upper_bound(a)-ds.lower_bound(a) );
if(!ds.insert(a).second) cout<<"Already Exist"<<endl;//这行代码借鉴的
return;
}
void outc(int a)
{
int num=*ds.upper_bound(a)-*ds.lower_bound(a);
auto is=ds.lower_bound(a);
if(!ds.size())
{
cout<<"Empty"<<endl;
return;
}
if(num)
{
cout<<*is<<endl;
ds.erase(is);
}
else
{
auto itis=ds.lower_bound(a),jtis=itis;
if(jtis!=ds.begin()) --jtis;
if(itis!=ds.end() && (a-(*jtis) > (*itis)-a))
jtis=itis;
cout<<(*jtis)<<endl;
ds.erase(jtis);
}
return;
}
int main()
{
cin>>ccc;
for(int i=1;i<=ccc;i++)
{
int op;
cin>>op;
if(op==1)
{
int x;
cin>>x;
inc(x);
}
if(op==2)
{
int x;
cin>>x;
outc(x);
}
}
return 0;
}
map用法
基本用法
#include<bits/stdc++.h>
using namespace std;
void the_map()
{
map<string,int>ds;
string kis="kis";
ds[kis]=2;ds["a+a"]=3;ds["b+"]=4;ds["c-"]=5;//这样就可将这个“数组”赋值
ds[kis];//查询ds[kis]的映射值
cout<<ds[kis];//输出
ds.end();
auto isit=ds.begin();
isit=ds.find("kis");//查询x在映射表中的地址
ds.size();
ds.erase("a+a");//删除下标为a+a的元素
return;//OK
}
int main()
{
the_map();
return 0;
}
例题P5266
【深基17.例6】学籍管理
题目描述
您要设计一个学籍管理系统,最开始学籍数据是空的,然后该系统能够支持下面的操作(不超过 $10^5$ 条):
- 插入与修改,格式
1 NAME SCORE:在系统中插入姓名为 NAME(由字母和数字组成不超过 20 个字符的字符串,区分大小写) ,分数为 SCORE (0 < SCORE < 2³¹) 的学生。如果已经有同名的学生则更新这名学生的成绩为 SCORE。如果成功插入或者修改则输出OK。 - 查询,格式
2 NAME:在系统中查询姓名为 NAME 的学生的成绩。如果没能找到这名学生则输出Not found,否则输出该生成绩。 - 删除,格式
3 NAME:在系统中删除姓名为 NAME 的学生信息。如果没能找到这名学生则输出Not found,否则输出Deleted successfully。 - 汇总,格式
4:输出系统中学生数量。
输入格式
输出格式
样例 #1
样例输入 #1
5
1 lxl 10
2 lxl
3 lxl
2 lxl
4
样例输出 #1
OK
10
Deleted successfully
Not found
0
思路
用一个map记录字符串与分数的对应关系
后面没有技术成分了
map模板题
code_AC
#include<bits/stdc++.h>
using namespace std;
int ccc;
map<string,int>stu;
int main()
{
cin>>ccc;
for(int i=1;i<=ccc;i++)
{
int kkk;cin>>kkk;
if(kkk==1)//插入
{
string op;int score;
cin>>op>>score;
stu[op]=score;
cout<<"OK"<<endl;
}
if(kkk==2)//查询
{
string op;cin>>op;
auto isit=stu.find(op);
if(isit==stu.end()) cout<<"Not found"<<endl;
else cout<<stu[op]<<endl;
}
if(kkk==3)//删除
{
string op;cin>>op;
auto isit=stu.find(op);
if(isit==stu.end()) cout<<"Not found"<<endl;
else
{
stu.erase(op);
cout<<"Deleted successfully"<<endl;
}
}
if(kkk==4) cout<<stu.size()<<endl;//汇总
}
return 0;
}
/*
思路
用一个map记录字符串与分数的对应关系
后面没有技术成分了
map模板题
*/
END 日有所进
基础数据结构->set&&map的更多相关文章
- 理解 OpenStack + Ceph (4):Ceph 的基础数据结构 [Pool, Image, Snapshot, Clone]
本系列文章会深入研究 Ceph 以及 Ceph 和 OpenStack 的集成: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 ...
- uoj #228. 基础数据结构练习题 线段树
#228. 基础数据结构练习题 统计 描述 提交 自定义测试 sylvia 是一个热爱学习的女孩子,今天她想要学习数据结构技巧. 在看了一些博客学了一些姿势后,她想要找一些数据结构题来练练手.于是她的 ...
- 【UOJ228】基础数据结构练习题(线段树)
[UOJ228]基础数据结构练习题(线段树) 题面 UOJ 题解 我们来看看怎么开根? 如果区间所有值都相等怎么办? 显然可以直接开根 如果\(max-sqrt(max)=min-sqrt(min)\ ...
- Redis基础——剖析基础数据结构及其用法
这是一个系列的文章,打算把Redis的基础数据结构.高级数据结构.持久化的方式以及高可用的方式都讲一遍,公众号会比其他的平台提前更新,感兴趣的可以提前关注,「SH的全栈笔记」,下面开始正文. 如果你是 ...
- 【UOJ#228】基础数据结构练习题 线段树
#228. 基础数据结构练习题 题目链接:http://uoj.ac/problem/228 Solution 这题由于有区间+操作,所以和花神还是不一样的. 花神那道题,我们可以考虑每个数最多开根几 ...
- hrbustoj 1551:基础数据结构——字符串2 病毒II(字符串匹配,BM算法练习)
基础数据结构——字符串2 病毒IITime Limit: 1000 MS Memory Limit: 10240 KTotal Submit: 284(138 users) Total Accepte ...
- hrbustoj 1545:基础数据结构——顺序表(2)(数据结构,顺序表的实现及基本操作,入门题)
基础数据结构——顺序表(2) Time Limit: 1000 MS Memory Limit: 10240 K Total Submit: 355(143 users) Total Accep ...
- 关于SparkMLlib的基础数据结构 Spark-MLlib-Basics
此部分主要关于MLlib的基础数据结构 1.本地向量 MLlib的本地向量主要分为两种,DenseVector和SparseVector,顾名思义,前者是用来保存稠密向量,后者是用来保存稀疏向量,其创 ...
- Vlc基础数据结构记录
1. Vlc基础数据结构 hongxianzhao@hotmail.com 1.1 基础数据结构 struct vlc_object_t,相关文件为src\misc\objects.c. 定义为: ...
- ES6 之 Set数据结构和Map数据结构 Iterator和for...of循环
ECMAScript 6 入门 Set数据结构 基本用法 ES6提供了新的数据结构Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set本身是一个构造函数,用来生成Set数据结构. va ...
随机推荐
- #PowerBi 1分钟学会,用PowerBi获取数据库最近90天的数据(DATE_SUB)
在powerbi报表中,我们往往会对数据源进行日常刷新,powerbi链接了数据库的情况下,根据日期灵活取数是我们必须掌握的一个技能. 在本文中,我们将介绍如何使用 SQL 的 DATE_SUB 函数 ...
- error while loading shared libraries: liblzma.so.5: cannot open shared object file: No such file or directory
CentOS6安装mongo报错 error while loading shared libraries: liblzma.so.5: cannot open shared object file: ...
- ubuntu16.04 安装 eclips c/c++
前言 最近需要在ubuntu16上使用eclips编译c,尝试了apt安装和官网最新包安装甚至应用商店安装,效果都不太理想,现在把我的安装方法记录一下. 正文 !!!前提,已经自己配置好了java8的 ...
- HTML5、CSS3 里面都新增了那些新特性?
HTML5 新的语义标签 article 独立的内容. aside 侧边栏. header 头部. nav 导航. section 文档中的节. footer 页脚. 画布(Canvas) API 地 ...
- SpringBoot 整合Easy Poi 下载Excel(标题带批注)、导出Excel(带图片)、导入Excel(校验参数,批注导出),附案例源码
导读 日常开发过程中,经常遇到Excel导入.导出等功能,其中导入逻辑相对麻烦些,还涉及到参数的校验,然后将错误信息批注导出.之前写过EasyExcel导入(参数校验,带批注)(点我直达1.点我直达2 ...
- 基于Docker安装项目管理工具禅道
禅道是通用的项目管理软件 完整支持敏捷项目模型.瀑布项目模型.看板模型 内置项目集.产品.项目和执行四个管理框架 支持CMMI标准的落地实施 下载镜像 docker pull easysoft/zen ...
- 全网最适合入门的面向对象编程教程:17 类和对象的Python实现-鸭子类型与“file-like object“
全网最适合入门的面向对象编程教程:17 类和对象的 Python 实现-鸭子类型与"file-like object" 摘要: 本文主要介绍了 Python 中创建自定义类时鸭子类 ...
- 业务场景---Token无感刷新
业务场景描述 假设用户正在填写一个复杂的表单,由于表单内容繁多,用户花费了很长时间才填完.这时,如果Token已经过期,系统会让用户重新登录,这种体验显然是非常糟糕的.为了避免这种情况,我们需要在To ...
- OpenStack 基本命令
keystone source /etc/keystone/admin-openrc.sh #登录 openstack user create --password ps1234 --email hq ...
- c++代码实现 RSA的简易demo【偏向实践】
写在前面 [如果你还没搞明白算法具体步骤建议先去看视频了解,本demo旨在简单实践该算法] 本实践在理论上是成立的,但由于计算x的时候很容易溢出,所以观者可以理解该简易demo后对数据进行处理[以字符 ...