Features Track[STL map]
题目地址
Features Track(ACM-ICPC 2018 徐州赛区网络预赛 )
题干


代码和解释
题意:一个动画有许多 n 帧,每帧有 k 个点,点的坐标 (x,y) 相同则视作同一个点。先要求找出在相邻帧存在的点最多的帧数是多少。比如:点 (1,4) 在第2、3、4、7、8帧存在,则其连续存在于 2-3-4 和 7-8 帧处,其连续存在的最多帧为3帧。
输入:T(样例组数),n(帧数),每帧输入k(此帧点数),其后跟着 2k 个整数表示 k 的点的 x 和 y 坐标。
如果对于每一帧的每一个点存起来后依次查找其位置,则时间复杂度过高。而 STL map 使用哈希,搜索快。并且使用01滚动的方式,只需要两帧、两个map(上一个和这一个),而不需要 n 个map就可以解决此题。
下面是本题的c++代码
#include<bits/stdc++.h>
using namespace std;
//只需要看这一位和上一位即可,来回01滚动
map< int,map<pair<int,int>,int> > mp;//外层的key是0或1,内层的key是点的值,内层的value是连续出现几次
pair<int,int> p;//点p坐标x和y
int main()
{
int T;
int n;
int k;
int x,y;
int ans;
int magic;//tql,magic只为0或1,异或计算
scanf("%d",&T);//样例组数
while(T--){
scanf("%d",&n);//几帧动画
magic = 0;//对于一个样例,初始化
ans = 0;
while(n--){
scanf("%d",&k);//这一帧有几个点
mp[magic].clear();//每帧一次,将旧的清0,当成新的
while(k--){
scanf("%d%d",&x,&y);
p=make_pair(x,y);//制造点
//1.如果magic=0,则magic^1=1。如果mp[1].count(p)不为0(则为1),说明在上一帧有p点
//2.如果magic=1,则magic^1=0。如果mp[0].count(p)不为0(则为1),说明在上一帧有p点
//3.如果magic=0,则magic^1=1。如果mp[1].count(p)为0,说明在上一行没有p点,而在这一帧出现了p点
//4.如果magic=1,则magic^1=0。如果mp[0].count(p)为0,说明在上一行没有p点,而在这一帧出现了p点
mp[magic][p]=mp[magic^1][p]+1;//更新p点的连续出现次数,比上次多1(上次可能是0,也可能不是0)
ans=max(ans,mp[magic][p]);//更新最大连续出现次数
//如果p点在这一帧没有出现,则对于这个p,不会走上面的这两帧。因为之前经过了每帧的 mp[magic].clear(),全部清0,所以下一次循环时,mp[magic^1][p]会为0,说明p点在这一帧没有出现。
}
magic^=1;//每帧一次。如果magic是1,则变为0;如果magic是0,则变为1。然后 mp[magic].clear(),清掉旧的,保留这次循环里留下的新的
}
printf("%d\n",ans);
}
return 0;
}
异或的特殊用法:偶数异或1会得到它加1,奇数异或1会得到它减1。所以使用异或1可以使0和1相互转化。
参考
ACM-ICPC2018徐州网络赛 Features Track(二维map+01滚动)
记异或的妙处(异或1)
- map:关联容器,实现从键(key)到值(value)的映射。
- map效率高的原因:用平衡二叉搜索树来存储和访问。
查找的复杂度是O(logn)。
| 例子 | 说明 |
|---|---|
| map<Type1,Type2> A; | 定义,key的类型是Type1,value的类型是Type2 |
| A[x] | 返回key x到value的引用,时间复杂度为O(logn),可以用于赋值。若x不存在,则自动新建一个二元组(x,zero),并返回zero的引用 |
| A.size() | 返回元素个数,时间复杂度O(1) |
| A.empty() | 判断是否为空 |
| A.clear() | 清空A |
| A.count(x) | 返回A中key为x的元素个数,时间复杂度为O(logn),因为map中一个key只对应一个value,所以A.count(x)只可能为0或1 |
| map<Type1,Type2>::iterator it | 定义迭代器it |
| it->first | 返回迭代器对应的key |
| it->second | 返回迭代器对应的value |
| A.find(x) | 在A中查找key为x的二元组,并返回指向该二元组的迭代器,若不存在,返回map.end(),时间复杂度为O(logn) |
| A.insert(pair<Type1,Type2>(x,v)) | 返回插入地址的迭代器和是否插入成功的bool并成的pair,时间复杂度为O(logn) |
| A.erase(参数) | 删除,参数可以是pair或者迭代器,返回下一个元素的迭代器,时间复杂度为O(logn) |
Features Track[STL map]的更多相关文章
- 计蒜客 31458.Features Track-滚动数组+STL(map)连续计数 (ACM-ICPC 2018 徐州赛区网络预赛 F)
F. Features Track Morgana is learning computer vision, and he likes cats, too. One day he wants to f ...
- ACM-ICPC2018徐州网络赛 Features Track(二维map+01滚动)
Features Track 31.32% 1000ms 262144K Morgana is learning computer vision, and he likes cats, too. ...
- stl::map之const函数访问
如何在const成员数中访问stl::map呢?例如如下代码: string ConfigFileManager::MapQueryItem(const string& name) const ...
- hdu4941 Magical Forest (stl map)
2014多校7最水的题 Magical Forest Magical Forest Time Limit: 24000/12000 MS (Java/Others) Memory Limit ...
- [CareerCup] 13.2 Compare Hash Table and STL Map 比较哈希表和Map
13.2 Compare and contrast a hash table and an STL map. How is a hash table implemented? If the numbe ...
- STL MAP及字典树在关键字统计中的性能分析
转载请注明出处:http://blog.csdn.net/mxway/article/details/21321541 在搜索引擎在通常会对关键字出现的次数进行统计,这篇文章分析下使用C++ STL中 ...
- POJ 3096 Surprising Strings(STL map string set vector)
题目:http://poj.org/problem?id=3096 题意:给定一个字符串S,从中找出所有有两个字符组成的子串,每当组成子串的字符之间隔着n字符时,如果没有相同的子串出现,则输出 &qu ...
- STL MAP 反序迭代
ITS_NOTICE_MAP::reverse_iterator it = noticeMap.rbegin(); for ( ; it != noticeMap.rend(); ++it ) { I ...
- 泛型Binary Search Tree实现,And和STL map比较的经营业绩
问题叙述性说明: 1.binary search tree它是一种二进制树的.对于key值.比当前节点左孩子少大于右子. 2.binary search tree不是自平衡树.所以,当插入数据不是非常 ...
随机推荐
- 《SAP微顾问和大数据 》公众号管理课程清单
互联网商业模式创新 电子商务与传统企业转型 “一带一路”信息化:格局与对策 “一带一路”沿线国家主权信用及风险防范 大数据下的资源整合和知识共享 地产数字化改革的痛点与处方 携手共建“一带一路” 数字 ...
- ReactiveObjC basic
基础-> https://www.jianshu.com/p/cd4031fbf8ff 在RAC中,万物皆信号. RAC 指的就是 RactiveCocoa ,是 Github 的一个开源框架, ...
- Dubbo 几个很实用但是很少人知道的功能
dubbo功能非常完善,很多时候我们不需要重复造轮子,下面列举一些你不一定知道,但是很好用的功能; 直连Provider 在开发及测试环境下,可能需要绕过注册中心,只测试指定服务提供者,这时候可能需要 ...
- Prometheus学习笔记(2)Prometheus部署
目录 Prometheus的安装配置启动 Prometheus的安装配置启动 1.Prometheus二进制安装 Prometheus下载链接:https://prometheus.io/downlo ...
- Sublime Text3 安装 CTags 插件出现乱码
1.下载ctags.exe 可以直接下载我上传好的资源:http://download.csdn.net/download/zhaoxd200808501/9971251.或者网络上其他地方也可以下载 ...
- 大数据:Hadoop(JDK安装、HDFS伪分布式环境搭建、HDFS 的shell操作)
所有的内容都来源与 Hadoop 官方文档 一.Hadoop 伪分布式安装步骤 1)JDK安装 解压:tar -zxvf jdk-7u79-linux-x64.tar.gz -C ~/app 添加到系 ...
- JVM存储位置分配——java中局部变量、实例变量和静态变量在方法区、栈内存、堆内存中的分配
Java中的变量根据不同的标准可以分为两类,以其引用的数据类型的不同来划分可分为“原始数据类型变量和引用数据类型变量”,以其作用范围的不同来区分可分为“局部变量,实例变量和静态变量”. 根据“Java ...
- 执行shell脚本时提示/bin/sh^M: bad interpreter: No such file or directory
执行脚本时提示解释器有问题,错误提示如下: 这种提示一般是脚本在windows系统之通过记事本写的,记事本修改过的文本,会默认在文本前面加上一些看不到的标记,导致shell脚本不能被shell解释器识 ...
- 接口自动化--requests库封装
前言 不管是自动化大佬还是自动化小白,都知道我们用python写接口自动化测试肯定是要用requests库来封装请求类的,下面就简单介绍下requests这个库 安装 一般都是直接采用pip命令安装: ...
- win7 创建vhd提示“找不到指定文件的虚拟磁盘支持提供程序”解决方法
本文参照:https://itbbs.pconline.com.cn/diy/16509116_2.html 14楼中"坚持不放弃"用户的答案得到解决 问题复现: 1.window ...