【题解】Luogu P5358 [SDOI2019]快速查询
原题传送门
神鱼说这道题是强制离线(smog
我们珂以把被单点修改,单点查询的点单独拿出来处理,把每个数表示成\(mul*x+plus\)
初始状态下\(mul=1,plus=0\)
操作1:在总和中减去\(val[pos[x]]\)(\(pos\)表示离散化后的位置,\(val\)表示特殊点的数值);将\(val[pos[x]]\)变成\(\frac{val_{new}-plus}{mul}\);如果\(pos[x]\)不在非零位置的栈中,将\(pos[x]\)压入栈中;在总和中加上\(val_{new}\)
操作2:将\(plus\)加上\(val\),将总和更新
操作3:当乘的值不为\(0\)时,将\(mul\)、\(plus\)和总和都乘上这个值;当乘的值为\(0\)时,将所有数赋值为\(0\),见操作4
操作4:把值不为\(0\)的栈弹空,并将\(val[sta[top]]\)变成\(0\),并且将\(mul\)变成\(1\),将\(plus\)变成\(val\),将总和更新
操作5/6:val[pos[x]]或总和
有除法,要处理逆元
#include <bits/stdc++.h>
#define N 100005
#define mod 10000019
#define getchar nc
using namespace std;
inline char nc(){
static char buf[100000],*p1=buf,*p2=buf;
return p1==p2&&(p2=(p1=buf)+fread(buf,1,100000,stdin),p1==p2)?EOF:*p1++;
}
inline int read()
{
register int x=0,f=1;register char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9')x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
return x*f;
}
inline void write(register int x)
{
if(!x)putchar('0');if(x<0)x=-x,putchar('-');
static int sta[20];register int tot=0;
while(x)sta[tot++]=x%10,x/=10;
while(tot)putchar(sta[--tot]+48);
}
inline int fastpow(register int a,register int b)
{
int res=1;
while(b)
{
if(b&1)
res=1ll*res*a%mod;
a=1ll*a*a%mod;
b>>=1;
}
return res;
}
int n,m,t,ans,b[N*100],tot,sum,mul=1,pls,inv=1,f[N],in[N];
inline void modify(register int x,register int y)
{
sum=(sum+1ll*(mod-f[x])*mul+mod-pls)%mod;
f[x]=1ll*(y-pls+mod)*inv%mod;
if(!in[x])
b[++tot]=x,in[x]=1;
sum=(sum+y)%mod;
}
inline void plu(register int y)
{
sum=(sum+1ll*n*y)%mod;
pls=(pls+y)%mod;
}
inline void cover(register int y)
{
while(tot)
f[b[tot]]=0,in[b[tot--]]=0;
mul=inv=1,pls=y;
sum=1ll*n*y%mod;
}
inline void mult(register int y,register int z)
{
if(y)
{
sum=1ll*sum*y%mod;
mul=1ll*mul*y%mod;
pls=1ll*pls*y%mod;
inv=1ll*inv*z%mod;
}
else
cover(0);
}
inline int query(register int x)
{
return (1ll*f[x]*mul+pls)%mod;
}
int opt[N],x[N],y[N],z[N];
int main()
{
n=read()%mod,m=read();
for(register int i=0;i<m;++i)
{
opt[i]=read();
if(opt[i]==1||opt[i]==5)
x[i]=b[++tot]=read();
if(opt[i]<=4)
y[i]=(read()%mod+mod)%mod,z[i]=fastpow(y[i],mod-2);
}
sort(b+1,b+1+tot);
tot=unique(b+1,b+1+tot)-b-1;
for(register int i=0;i<m;++i)
if(opt[i]==1||opt[i]==5)
x[i]=lower_bound(b+1,b+1+tot,x[i])-b;
t=read();
for(register int i=tot=0;i<t;++i)
{
int a=read()%m,b=read()%m;
for(register int j=0,k=(a+b)%m;j<m;++j,k=(k+b)%m)
{
int o=opt[k];
if(o==1)
modify(x[k],y[k]);
else if(o==2)
plu(y[k]);
else if(o==3)
mult(y[k],z[k]);
else if(o==4)
cover(y[k]);
else if(o==5)
ans=(ans+query(x[k]))%mod;
else
ans=(ans+sum)%mod;
}
}
write(ans);
return 0;
}
【题解】Luogu P5358 [SDOI2019]快速查询的更多相关文章
- luogu P5358 [SDOI2019]快速查询【模拟(?)】
把有单点修改和查询的点离散进一个数组,然后单点修改直接改,记录一个修改时间t,维护一个sm表示这些离散的点的和,val表示出了离散点其他点的值,因为都是一样的所以只记录这一个值即可,记录ljlc为加法 ...
- P5358 [SDOI2019]快速查询
思路:...乱搞数据结构?? 提交:1次 题解: 观察到除了单点就是全局操作,所以我们维护一个全局加法标记add和乘法标记mul和答案sum. 单点修改时,比如我们要把 \(pos\) 位置改成 \( ...
- [SDOI2019]快速查询——模拟
题目链接: [SDOI2019]快速查询 对于整个序列维护一个标记$(k,b)$表示序列的每个数的真实值为$k*a_{i}+b$(注意要实时维护$k$的逆元),并记录序列的和. 对于单点修改,将$a_ ...
- [SDOI2019]快速查询
[SDOI2019]快速查询 [题目链接] 链接 [思路要点] 据说是 \(\text{SDOI2019}\) 最水的题 操作次数为 \(1e7\) 范围,显然要求每次操作 \(\mathcal{O} ...
- vijos2051 SDOI2019 快速查询
题目链接 吐槽 竟然让\(nlog\)的做法卡过去了.. 思路 因为\(1 \le q \le 10^5\),所以可以先对每个标准操作,所操作的位置进行重标号.这样所有的下标都是在\(10^5\)以内 ...
- 【洛谷5358】[SDOI2019] 快速查询(模拟)
点此看题面 大致题意: 有单点赋值.全局加法.全局乘法.全局赋值.单点求值.全局求和\(6\)种操作.现在给出操作序列,以及\(t\)对正整数\(a_i,b_i\).让你处理\(t*q\)次操作,每次 ...
- SDOI2019快速查询
链接 vijos 思路 虽然询问1e7,但他询问很有意思,所以最多修改1e5个. 先把他们修改的点缩小到1e5之内并没有什么影响. 然后维护mul和add.不修改很好弄,修改的点可以弄点式子加加减减弄 ...
- 快速查询Python脚本语法
/********************************************************************* * 快速查询Python脚本语法 * 说明: * Char ...
- 一种快速查询多点DS18B20温度的方法(转)
源:http://hi.baidu.com/james_xiao/item/79b961c90623093e45941623 一种快速查询多点DS18B20温度的方法 引言 为了满足实时性要 ...
随机推荐
- pytest + allure 生成测试报告
pytest测试样例规则:测试文件以test_开头(以_test结尾也可以)测试类以Test开头,并且不能带有 init 方法测试函数以test_开头断言使用基本的assert即可 ubuntu 安装 ...
- 歪国人整理的 2019 年 Java 开发路线图,值得参考!
许多Java开发人员都希望通过某种Java成长路线图,来解答有关:该学习哪些技术,使用哪些工具以及框架之类的问题. 在此,我将向大家展示一张根据自己多年经验总结出的路线图.该路线图在保持简单可行的 ...
- JPA的动态查询拼接
在使用Spring JPA提供的方法只能进行简单的CRUD,如果遇到复杂的情况就需要我们动态来构建查询条件了.这里我们来看使用CriteriaBuilder如何来构造查询.核心代码: Criteria ...
- Vue使用NProgress
NProgress是页面跳转是出现在浏览器顶部的进度条官网:http://ricostacruz.com/nprogress/github:https://github.com/rstacruz/np ...
- win10下通过编译源码方式在chrome中成功安装react-devtools开发工具插件
win10下通过编译源码方式在chrome中成功安装react-devtools开发工具插件 1.去git上下载react-devtools文件到本地,https://github.com/fac ...
- odoo开发笔记 -- 用户字段值,默认给当前登录用户
场景描述: 在一些视图下,当系统用户创建某条记录的时候,需要给某个用户字段设置默认值,即:默认值为系统的当前登录用户,如何实现? 处理方式: 在定义模型的时候,给该字段赋值就可以: operator_ ...
- canvas笔记备忘
备忘 1. canvas标签的宽和高设置是标签属性设置, 不是 css 属性设置. 如果用 css 属性设置大小, canvas 会被拉伸. 标签属性例如: class, id, style, wid ...
- scrapy爬虫案例:问政平台
问政平台 http://wz.sun0769.com/index.php/question/questionType?type=4 爬取投诉帖子的编号.帖子的url.帖子的标题,和帖子里的内容. it ...
- zookeeper+Dubbo环境搭建及简单Demo
1 安装zk https://www.cnblogs.com/feifeicui/p/11175502.html 2 安装 dubbo-admin https://www.cnblogs.com/fe ...
- bilibili投屏到电脑
bilibili投屏到TV B栈上有丰富的视频资源,电视盒子小米,自带匹配的投屏功能. 但是如何将哔哩哔哩投屏到电脑上? bilibili投屏到PC上 万能的知乎给出了答案. https://www. ...