玩(lay) 解题报告
玩(lay)
题目名称
你的昆特牌打的太好啦!不一会你就 \(\tt{AK}\) 了 \(\tt{NOGP}\),只能无聊地堆牌玩!
题目描述
你有一些矩形卡牌,每次你会作如下三个操作:
- 紧挨着最后一张牌往牌后面放一张牌,这张牌的底边与 \(X\) 轴重合且位于第一象限。(第一张牌最左边位于 \(X=0\) 处)
- 拿走一张牌, 并把后面的牌向前推到与前一张牌右边重合。
- 询问\([l , r]\)(坐标) 这一段牌最高的高度。
对于边界情况,在两张牌交界处视为最高的那张牌的高度。
输入输出可能需要加速!
输入输出格式
输入格式
第一行两个数 \(N\)、 \(C\) 表示操作数、 离线操作还是在线;
接下来 \(N\) 行每行是如下三种之一
\(T=1\),接下来 \(LEN\)、 \(H\) 分别表示插入的牌的长、高;
\(T=2\),接下来 \(X\) 表示拿走哪一张牌, 牌的编号按出现顺序由小到大, 从 \(1\) 开始(不是操作序号!), 删除的牌不会改变序号, 若序号表示的牌已被删除则不操作;
\(T=3\), 接下来 \(L\)、 \(R\) 表示询问区间; 若询问区间上没牌,输出 \(0\)。
若 \(C=1\),则上面输入中的 \(LEN\)、 \(H\)(仅这两项!) 需要以下式子算出(\(lastans\) 为最近一次询问答案,初值为 \(0\))
真实输入\(=(\)输入\(\times 2333 + lastans\times 666 )\pmod{10^8+7}+1\)。
输出格式
对每一个询问操作输出该段最高的位置高度是多少。
说明
对于\(40\%\)的数据,没有删除操作;
对于额外\(20\%\)的数据, \(C=0\);
对于\(80\%\)的数据, \(N\le 2 \times 10^5\);
对于\(100\%\)的数据, \(N \le 5\times 10^5\) , \(LEN,H\le 10^9\), \(L\)、 \(R\) 不会超过 \(10^{18}\) 范围, 输入的没有负数
并不难。
上午打了一个\(fhq\)平衡树维护,因为写了三个\(\tt{split}\)再加上第一题模拟写挂写的很烦,然后就挂了。
下午换了思路写了写线段树。
主题思路是对进入的牌的顺序建线段树,维护区间长度加和区间高度最大值
每次询问的时候现在线段树上二分一下找到询问的区间,然后再进去询问就可以了。
(结果还是写了三个\(\tt{query}\),事实上一个应该就可以了
删除插入都比较简单了。
Code:
#include <cstdio>
#define ll long long
const int N=5e5+10;
ll sum[N<<2],mx[N<<2];
#define ls id<<1
#define rs id<<1|1
ll Max(ll x,ll y){return x>y?x:y;}
void updata(int id)
{
sum[id]=sum[ls]+sum[rs];
mx[id]=Max(mx[ls],mx[rs]);
}
void change(int id,int l,int r,int p,ll d,ll h)
{
if(l==r)
{
sum[id]=d,mx[id]=h;
return;
}
int mid=l+r>>1;
if(p<=mid) change(ls,l,mid,p,d,h);
else change(rs,mid+1,r,p,d,h);
updata(id);
}
int queryL(int id,int l,int r,ll p)
{
if(l==r) return l;
int mid=l+r>>1;
if(sum[ls]<p) return queryL(rs,mid+1,r,p-sum[ls]);
else return queryL(ls,l,mid,p);
}
int queryR(int id,int l,int r,ll p)
{
if(l==r) return l;
int mid=l+r>>1;
if(sum[ls]<=p) return queryR(rs,mid+1,r,p-sum[ls]);
else return queryR(ls,l,mid,p);
}
int query(int id,int L,int R,int l,int r)
{
if(l==L&&r==R) return mx[id];
int Mid=L+R>>1;
if(r<=Mid) return query(ls,L,Mid,l,r);
else if(l>Mid) return query(rs,Mid+1,R,l,r);
else return Max(query(ls,L,Mid,l,Mid),query(rs,Mid+1,R,Mid+1,r));
}
int main()
{
int c,op,n,In=0;
scanf("%d%d",&n,&c);
ll lastans=0,LEN,H,l,r;int id;
for(int i=1;i<=n;i++)
{
scanf("%d",&op);
if(op==1)
{
scanf("%lld%lld",&LEN,&H);
if(c==1)
{
LEN=(LEN*2333+lastans*666)%100000007+1;
H=(H*2333+lastans*666)%100000007+1;
}
change(1,1,n,++In,LEN,H);
}
else if(op==3)
{
scanf("%lld%lld",&l,&r);
printf("%lld\n",lastans=query(1,1,n,queryL(1,1,n,l),queryR(1,1,n,r)));
}
else
{
scanf("%d",&id);
change(1,1,n,id,0,0);
}
}
return 0;
}
2018.11.6
玩(lay) 解题报告的更多相关文章
- 洛谷 P4705 玩游戏 解题报告
P4705 玩游戏 题意:给长为\(n\)的\(\{a_i\}\)和长为\(m\)的\(\{b_i\}\),设 \[ f(x)=\sum_{k\ge 0}\sum_{i=1}^n\sum_{j=1}^ ...
- 「SCOI2015」小凸玩矩阵 解题报告
「SCOI2015」小凸玩矩阵 我好沙茶啊 把点当边连接行和列,在外面二分答案跑图的匹配就行了 我最开始二分方向搞反了,样例没过. 脑袋一抽,这绝壁要费用流,连忙打了个KM 然后wa了,一想这个不是完 ...
- 「SCOI2015」小凸玩密室 解题报告
「SCOI2015」小凸玩密室 虽然有心里在想一些奇奇怪怪的事情的原因,不过还是写太久了.. 不过这个题本身也挺厉害的 注意第一个被点亮的是任意选的,我最开始压根没注意到 \(dp_{i,j}\)代表 ...
- 【NOIP2015】提高组D1 解题报告
P1978神奇的幻方 Accepted 描述 幻方是一种很神奇的 N ∗ N 矩阵:它由数字 1,2,3, … … , N ∗ N 构成,且每行.每列及两条对角线上的数字之和都相同. 当 N 为奇数时 ...
- $HNOI\ 2010$ 解题报告
HNOI 2010 解题报告 0. HNOI2010 AC代码包下载地址 注: 戳上面的标题中的'地址' 下载 代码包, 戳下面每一题的文件名 可进入 题目链接. 每一题 对应代码的文件名 我在 每一 ...
- 【百度之星2014~复赛 解题报告~正解】The Query on the Tree
声明 笔者最近意外的发现 笔者的个人网站http://tiankonguse.com/ 的很多文章被其它网站转载,但是转载时未声明文章来源或参考自 http://tiankonguse.com/ 网站 ...
- 【百度之星2014~复赛)解题报告】The Query on the Tree
声明 笔者最近意外的发现 笔者的个人网站http://tiankonguse.com/ 的很多文章被其它网站转载,但是转载时未声明文章来源或参考自 http://tiankonguse.com/ 网站 ...
- USACO Section2.2 Party Lamps 解题报告 【icedream61】
lamps解题报告------------------------------------------------------------------------------------------- ...
- NOIP 2018 普及组 解题报告
目录 标题统计 题目链接 思路 代码 龙虎斗 题目链接: 思路 代码 摆渡车 题目链接: 思路 对称二叉树 题目链接 思路: 先来解释一下为毛现在才来发解题报告: 其实博主是参加过NOIP 2018普 ...
随机推荐
- Qt-QPalette-调色板学习
已经很久没有更新博客了,一是因为换了公司,完全是断网开发了,没有时间来写博客,最主要的就是温水煮青蛙,自己在舒适的环境中越来越懒了,最近打算强制自己更新一波.不知道能坚持多久.由于目前没有具体的Qt项 ...
- 怎么设计好移动APP测试用例
软件测试工作中我们需要不断的储备和总结自己的知识和经验,怎么设计好移动APP测试用例?如:手机.平板.智能设备,并在特定网络环境下. 我们需要关注的功能点,容易出错的位置,这将对我们整个测试过程起着至 ...
- 校招小白机考入坑之从键盘输入java的各种数据类型
//1.从键盘输入一个整型(其他基本类型类似) Scanner sc =new Scanner(System.in); sc.hasNextInt(); int str1 = sc.nextInt() ...
- 微软的XML可视化编辑器:XML Notepad 2007
最近项目需要定义xml协议格式,编写xml文件比较多,之前使用xml spy工具,但是不够轻量级. 微软提供的xml nodepad 2007很实用,希望能给大家提供帮助. 运行后的界面 下载地址:h ...
- qt qchart缩放后坐标轴间隔取整
使用qt的qchart显示数据曲线,坐标轴QValueAxis可以设置刻度间隔数量,但每个刻度的数值是根据坐标的极值除以间隔数量得到的,不一定是整数,导致曲线控件的显示刻度不适合观察. 如图: 纵坐标 ...
- 6.azkban的监控
azkaban自带的监控flow自带的邮件功能SLA总结写程序监控job情况监控azkaban的元数据库使用azkaban API监控总结 azkaban自带的监控 azkban目前仅仅支持邮件监控, ...
- 基础数据类型-dict
字典Dictinary是一种无序可变容器,字典中键与值之间用“:”分隔,而与另一个键值对之间用","分隔,整个字典包含在{}内: dict1 = {key1:value1, key ...
- dataTables工作总结
近期在工作中用到了dataTables,现在总结一下在工作中遇到的问题以及解决方法,如有不妥之处希望多多指教,定会改进. 首先这里用的是coloradmin框架,在vs环境下开发. 这里写一个容器用于 ...
- Coursera:Internet History ,Techornology and Security
WEEK1 War Time Computing and Communication Bletchley Park 布莱彻利庄园:a top-secret code breaking effort b ...
- 福大软工1816:Alpha(8/10)
Alpha 冲刺 (8/10) 队名:第三视角 组长博客链接 本次作业链接 团队部分 团队燃尽图 工作情况汇报 张扬(组长) 过去两天完成了哪些任务: 文字/口头描述: 1. 2. 展示GitHub当 ...