【洛谷P3792】由乃与大母神原型和偶像崇拜
题目大意:维护一个序列,支持单点修改和查询一段区间能不能组成连续的一段数。
题解:查询区间能不能组成一段连续的数这个操作较为复杂,很难在较小时间复杂度内直接维护。这里采用线段树维护区间哈希的策略,即:维护一些其他的值间接地去逼近正解。在这里维护区间最大值、最小值、区间和、区间平方和、区间立方和即可。另外,由于数据范围 1e9,需要进行取模操作。
(脸黑,交了好几次才过。。QAQ
代码如下
#include <bits/stdc++.h>
using namespace std;
const int maxn=5e5+10;
const long long inf=1e18;
const int mod=1e9+7;
inline int read(){
int x=0,f=1;char ch;
do{ch=getchar();if(ch=='-')f=-1;}while(!isdigit(ch));
do{x=x*10+ch-'0';ch=getchar();}while(isdigit(ch));
return f*x;
}
int n,m;
long long a[maxn],s1,s2,s3,mi,mx;
struct node{
#define ls(x) t[x].lc
#define rs(x) t[x].rc
int lc,rc;
long long sum,sum2,sum3,mi,mx;
}t[maxn<<1];
int tot,root;
inline void pushup(int x){
t[x].mi=min(t[ls(x)].mi,t[rs(x)].mi);
t[x].mx=max(t[ls(x)].mx,t[rs(x)].mx);
t[x].sum=t[ls(x)].sum+t[rs(x)].sum;
t[x].sum2=(t[ls(x)].sum2+t[rs(x)].sum2)%mod;
t[x].sum3=(t[ls(x)].sum3+t[rs(x)].sum3)%mod;
}
int build(int l,int r){
int x=++tot;
if(l==r){t[x].mi=t[x].mx=t[x].sum=a[l],t[x].sum2=a[l]*a[l]%mod,t[x].sum3=t[x].sum2*a[l]%mod;return x;}
int mid=l+r>>1;
ls(x)=build(l,mid),rs(x)=build(mid+1,r);
return pushup(x),x;
}
void modify(int x,int l,int r,int pos,long long val){
if(l==r){t[x].mi=t[x].mx=val,t[x].sum=val,t[x].sum2=val*val%mod,t[x].sum3=t[x].sum2*val%mod;return;}
int mid=l+r>>1;
if(pos<=mid)modify(ls(x),l,mid,pos,val);
else modify(rs(x),mid+1,r,pos,val);
pushup(x);
}
void query(int o,int l,int r,int x,int y){
if(l==x&&r==y){
mi=min(mi,t[o].mi),mx=max(mx,t[o].mx);
s1+=t[o].sum,s2=(s2+t[o].sum2)%mod,s3=(s3+t[o].sum3)%mod;
return;
}
int mid=l+r>>1;
if(y<=mid)query(ls(o),l,mid,x,y);
else if(x>mid)query(rs(o),mid+1,r,x,y);
else query(ls(o),l,mid,x,mid),query(rs(o),mid+1,r,mid+1,y);
}
void read_and_parse(){
n=read(),m=read();
for(int i=1;i<=n;i++)a[i]=read();
root=build(1,n);
}
long long qs2(long long x){return x*(x+1)%mod*(2*x+1)%mod;}
long long qs3(long long x){return x*(x+1)%mod*x%mod*(x+1)%mod;}
void solve(){
while(m--){
int opt=read();
if(opt==1){
int pos=read(),val=read();
modify(root,1,n,pos,val);
}else if(opt==2){
mi=inf,mx=-inf,s1=s2=s3=0;
int l=read(),r=read();
query(root,1,n,l,r);
if(mx-mi!=r-l)puts("yuanxing");
else if((mi+mx)*(r-l+1)/2!=s1)puts("yuanxing");
else if(s2*6%mod!=((qs2(mx)-qs2(mi-1))%mod+mod)%mod)puts("yuanxing");
else if(s3*4%mod!=((qs3(mx)-qs3(mi-1))%mod+mod)%mod)puts("yuanxing");
else puts("damushen");
}
}
}
int main(){
read_and_parse();
solve();
return 0;
}
【洛谷P3792】由乃与大母神原型和偶像崇拜的更多相关文章
- 洛谷P3792 由乃与大母神原型和偶像崇拜
P3792 由乃与大母神原型和偶像崇拜 题目背景 由乃最近没事干,去研究轻拍学去了 就是一个叫做flip flappers,轻拍翻转小膜女的番 然后研究的过程中她看到了一个叫做大母神原型的东西 大母神 ...
- p3792 由乃与大母神原型和偶像崇拜(思维+线段树)
要求 1.修改x位置的值为y 2.查询区间l,r是否可以重排为值域上连续的一段 可以,很lxl 然后一开始思考合并区间,但是发现可以重排序,GG 然后想了特殊性质,比如求和,但是显然可以被叉 这时候我 ...
- AC日记——由乃与大母神原型和偶像崇拜 洛谷 P3792
由乃与大母神原型和偶像崇拜 思路: 逆元+线段树维护和+线段树维护平方和+线段树维护最大最小值: 代码: #include <bits/stdc++.h> using namespace ...
- LuoguP3792 由乃与大母神原型和偶像崇拜
题目地址 题目链接 题解 由乃题还是毒瘤啊orz 显然的一个结论是,如果保证不重复,维护区间min,max然后判断max-min+1==r-l+1是否成立即可 但是有重复 于是就要orz题解区的各位大 ...
- 「Luogu 3792」由乃与大母神原型和偶像崇拜
更好的阅读体验 Portal Portal1: Luogu Description 给你一个序列\(a\) 每次两个操作: 修改\(x\)位置的值为\(y\): 查询区间\([l, r]\)是否可以重 ...
- 洛谷P4014 分配问题【最小/大费用流】题解+AC代码
洛谷P4014 分配问题[最小/大费用流]题解+AC代码 题目描述 有 n 件工作要分配给 n 个人做.第 i 个人做第 j 件工作产生的效益为c ij. 试设计一个将 n 件工作分配给 n 个人做的 ...
- 洛谷——P1966 火柴排队&&P1774 最接近神的人_NOI导刊2010提高(02)
P1966 火柴排队 这题贪心显然,即将两序列中第k大的数的位置保持一致,证明略: 树状数组求逆序对啦 浅谈树状数组求逆序对及离散化的几种方式及应用 方法:从前向后每次将数插入到bit(树状数组)中, ...
- 洛谷 P1373 小a和uim之大逃离
2016-05-30 12:31:59 题目链接: P1373 小a和uim之大逃离 题目大意: 一个N*M的带权矩阵,以任意起点开始向右或者向下走,使得奇数步所得权值和与偶数步所得权值和关于K的余数 ...
- 洛谷1373 小a和uim之大逃离
洛谷1373 小a和uim之大逃离 本题地址:http://www.luogu.org/problem/show?pid=1373 题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北 ...
随机推荐
- Salesforce随笔: 将Visualforce Page导出为 Excel/CSV/txt (Display a page in Excel)
想要实现如题所述功能,可以参照 : Visualforce Developer Guide 第57页中所举的例子,在<apex:page>标签中添加contentType属性. <a ...
- [T-ARA N4/二段横踢][Can We Love]
歌词来源:http://music.163.com/#/song?id=26310867 Can We Love Can We Love [Can We Love Can We Love] Can W ...
- python基础学习笔记(四)
列表 本节继续讨论列表不同元组和字符串的地方:列表是可变的(mutable)----可以改变列表的内容,并且列表有很多有用的.专门的方法. List函数可以将一个字符串拆分成列表. >>& ...
- Vuex实现原理解析
我们在使用Vue.js开发复杂的应用时,经常会遇到多个组件共享同一个状态,亦或是多个组件会去更新同一个状态,在应用代码量较少的时候,我们可以组件间通信去维护修改数据,或者是通过事件总线来进行数据的传递 ...
- 腾讯QQ的商业模式
近期听到许多关于腾讯QQ的报道,然后想到之前自己在QQ上遇到的一些问题,一瞬间感觉大脑的所有想法喷涌而出. 以前总觉得QQ是个很好的平台,我们可以通过QQ和自己的亲人朋友爱人聊天,有时候还可以在自己的 ...
- Linux内核分析——第三章 进程管理
第三章 进程管理 3.1 进程 1.进程就是处于执行期的程序:进程就是正在执行的程序代码的实时结果:进程是处于执行期的程序以及相关的资源的总称:进程包括代码段和其他资源. 线程:是在进程中活动的对象. ...
- let命令和块级作用域
学习了阮一峰老师的ES6,http://es6.ruanyifeng.com/,收益良多. 一.let命令1.概念:let命令用于声明变量,和var类似,但是使用let命令所声明的变量只有在该变量所在 ...
- 申港集中运营平台Linux测试环境架构搭建
架构图 服务一览 ESB安装 ESB全称为Enterprise Service Bus,即企业服务总线.ESB提供了网络中最基本的连接中枢,是构筑企业神经系统的必要元素.ESB的出现改变了传统的软件架 ...
- 『编程题全队』Beta 阶段冲刺博客四
1.提供当天站立式会议照片一张 2.每个人的工作 (有work item 的ID) (1) 昨天已完成的工作 孙志威: 1.新增添加提醒事项的按钮 2.添加了新建提醒框 3.测试了新的SubTask思 ...
- HTML DOM 学习笔记
一.HTML DOM定义了所有HTML元素的对象和属性,以及访问他们的方法即:HTML DOM是关于如何获取,修改,添加,删除HTML元素的标准二.DOM节点1.分类整个文档是一个文档节点每个HTML ...