把式子展开以后会发现,可以用线段树维护$x,y,x*y,x^2$分别的区间和

然后操作有区间加和区间修改

这个pushdown的时候,如果改和加的标记同时存在,那一定是先改再加,要不然加的标记已经被清掉了

所以在pushdown的时候,如果有改的标记,要把孩子的加的标记清掉

然后注意细节就行了(用*传数组 然后在函数里改了的话 它真的会改的 怎么就意识不到呢...)

 #include<bits/stdc++.h>
#define pa pair<int,int>
#define CLR(a,x) memset(a,x,sizeof(a))
using namespace std;
typedef long long ll;
const int maxn=1e5+,inf=1e9; inline ll rd(){
ll x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} struct Node{
double x,y,xy,x2;
int l,r;
Node(double a=,double b=,double c=,double d=,int e=,int f=){
x=a,y=b,xy=c,x2=d,l=e,r=f;
}
}tr[maxn*];
double laz[maxn*][];
int ch[maxn*][],pct,X[maxn],Y[maxn];
int N,M; Node operator + (Node a,Node b){
Node p;
p.l=a.l,p.r=b.r;
p.x=a.x+b.x,p.y=a.y+b.y;
p.xy=a.xy+b.xy,p.x2=a.x2+b.x2;
return p;
} inline void deal(Node &p,double *v){
int r=p.r,l=p.l;
if(v[]!=-inf){
p.x=p.y=1ll*(p.r+p.l)*(p.r-p.l+)/;
p.xy=p.x2=(1ll*r*(r+)*(*r+))/-(1ll*(l-)*l*(*l-))/;
v[]+=v[],v[]+=v[];
} p.x2+=(p.r-p.l+)*v[]*v[]+*v[]*p.x;
p.xy+=v[]*p.y+v[]*p.x+(p.r-p.l+)*v[]*v[];
p.x+=(p.r-p.l+)*v[],p.y+=(p.r-p.l+)*v[];
if(v[]!=-inf) v[]-=v[],v[]-=v[];
} inline void pushdown(int p){
// return;
if(!ch[p][]) return;
if(laz[p][]==&&laz[p][]==&&laz[p][]==-inf) return;
int a=ch[p][],b=ch[p][];
if(laz[p][]!=-inf){
laz[a][]=laz[a][]=laz[b][]=laz[b][]=;
laz[a][]=laz[p][],laz[a][]=laz[p][];
laz[b][]=laz[p][],laz[b][]=laz[p][];
}
laz[a][]+=laz[p][],laz[a][]+=laz[p][];
laz[b][]+=laz[p][],laz[b][]+=laz[p][]; deal(tr[a],laz[p]);
deal(tr[b],laz[p]);
laz[p][]=laz[p][]=,laz[p][]=laz[p][]=-inf;
} void build(int &p,int l,int r){
p=++pct;
laz[p][]=laz[p][]=-inf;
if(l==r){
tr[p]=Node(X[l],Y[l],1ll*X[l]*Y[l],1ll*X[l]*X[l],l,r);
}else{
int m=l+r>>;
build(ch[p][],l,m);
build(ch[p][],m+,r);
tr[p]=tr[ch[p][]]+tr[ch[p][]];
}
} void query(int p,int l,int r,int x,int y,Node &q){
pushdown(p);
if(x<=l&&r<=y){
if(!q.l) q=tr[p];
else q=q+tr[p];
}else{
int m=l+r>>;
if(x<=m) query(ch[p][],l,m,x,y,q);
if(y>=m+) query(ch[p][],m+,r,x,y,q);
}
} void add(int p,int l,int r,int x,int y,int s,int t){
pushdown(p);
if(x<=l&&r<=y){
double v[];
v[]=s,v[]=t;v[]=v[]=-inf;
deal(tr[p],v);
laz[p][]+=s,laz[p][]+=t;
pushdown(p);
}else{
int m=l+r>>;
if(x<=m) add(ch[p][],l,m,x,y,s,t);
if(y>=m+) add(ch[p][],m+,r,x,y,s,t);
tr[p]=tr[ch[p][]]+tr[ch[p][]];
}
} void change(int p,int l,int r,int x,int y,int s,int t){
if(x<=l&&r<=y){
double v[];
v[]=v[]=,v[]=s,v[]=t;
deal(tr[p],v);
laz[p][]=laz[p][]=,laz[p][]=s,laz[p][]=t;
pushdown(p);
}else{
pushdown(p);
int m=l+r>>;
if(x<=m) change(ch[p][],l,m,x,y,s,t);
if(y>=m+) change(ch[p][],m+,r,x,y,s,t);
tr[p]=tr[ch[p][]]+tr[ch[p][]];
}
} int main(){
int i,j,k;
N=rd(),M=rd();
for(i=;i<=N;i++) X[i]=rd();
for(i=;i<=N;i++) Y[i]=rd();
build(i,,N);
for(i=;i<=M;i++){
int a=rd(),b=rd(),c=rd();
if(a==){
Node p;
query(,,N,b,c,p);
double xb=p.x/(c-b+),yb=p.y/(c-b+);
double ans=;
ans=p.xy-xb*p.y-yb*p.x+xb*yb*(c-b+);
ans/=p.x2-*xb*p.x+xb*xb*(c-b+);
printf("%.10lf\n",ans);
}else{
int d=rd(),e=rd();
if(a==){
add(,,N,b,c,d,e);
}else if(a==){
change(,,N,b,c,d,e);
}
}
}
return ;
}

luogu3707 相关分析 (线段树)的更多相关文章

  1. [Sdoi2017]相关分析 [线段树]

    [Sdoi2017]相关分析 题意:沙茶线段树 md其实我考场上还剩一个多小时写了40分 其实当时写正解也可以吧1h也就写完了不过还要拍一下 正解代码比40分短2333 #include <io ...

  2. 【BZOJ4821】【SDOI2017】相关分析 [线段树]

    相关分析 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description Frank对天文学非常感兴趣,他经 ...

  3. 【BZOJ4821】[Sdoi2017]相关分析 线段树

    [BZOJ4821][Sdoi2017]相关分析 Description Frank对天文学非常感兴趣,他经常用望远镜看星星,同时记录下它们的信息,比如亮度.颜色等等,进而估算出星星的距离,半径等等. ...

  4. BZOJ 4821 [Sdoi2017]相关分析 ——线段树

    打开题面,看到许多$\sum$ woc,好神啊,SDOI好强啊 然后展开之后,woc,SDOI好弱啊,怎么T3出个线段树裸题啊. 最后写代码的时候,woc,SDOI怎么出个这么码农的题啊,怎么调啊. ...

  5. 洛谷P3707 [SDOI2017]相关分析(线段树)

    题目描述 Frank对天文学非常感兴趣,他经常用望远镜看星星,同时记录下它们的信息,比如亮度.颜色等等,进而估算出星星的距离,半径等等. Frank不仅喜欢观测,还喜欢分析观测到的数据.他经常分析两个 ...

  6. BZOJ 4821: [Sdoi2017]相关分析 线段树 + 卡精

    考试的时候切掉了,然而卡精 + 有一个地方忘开 $long long$,完美挂掉 $50$pts. 把式子化简一下,然后直接拿线段树来维护即可. Code: // luogu-judger-enabl ...

  7. BZOJ.4821.[SDOI2017]相关分析(线段树)

    BZOJ LOJ 洛谷 恶心的拆式子..然后就是要维护\(\sum x_i,\ \sum y_i,\ \sum x_iy_i,\ \sum x_i^2\). 操作三可以看成初始化一遍,然后同操作二. ...

  8. SDOI2017相关分析 线段树

    题目 https://loj.ac/problem/2005 思路 \[ \sum_{L}^{R}{(x_i-x)^{2}} \] \[ \sum_{L}^{R}{(x_i^2-2*x_i*x+x^{ ...

  9. LOJ #2005. 「SDOI2017」相关分析 线段树维护回归直线方程

    题目描述 \(Frank\) 对天文学非常感兴趣,他经常用望远镜看星星,同时记录下它们的信息,比如亮度.颜色等等,进而估算出星星的距离,半径等等. \(Frank\) 不仅喜欢观测,还喜欢分析观测到的 ...

随机推荐

  1. EZ 2018 06 10 NOIP2018 模拟赛(十八)

    好久没写blog&&比赛题解了,最近补一下 这次还是很狗的,T3想了很久最后竟然连并查集都忘写了,然后T2map莫名爆炸. Rating爆减......链接不解释 好了我们开始看题. ...

  2. Scala学习(五)练习

    Scala中的类&练习 1. 改进Counter类,让它不要在Int.MaxValue时变成负数 程序代码: class Counter { private var value=100 def ...

  3. Quartz_配置

    quartz_jobs.xml job 任务 其实就是1.x版本中的<job-detail>,这个节点是用来定义每个具体的任务的,多个任务请创建多个job节点即可 name(必填) 任务名 ...

  4. 2018年高教社杯全国大学生数学建模竞赛D题解题思路

    题目 D题   汽车总装线的配置问题 一.问题背景 某汽车公司生产多种型号的汽车,每种型号由品牌.配置.动力.驱动.颜色5种属性确定.品牌分为A1和A2两种,配置分为B1.B2.B3.B4.B5和B6 ...

  5. HashMap和HashTable区别【转载】

    今天看到的HashMap和HashTable区别介绍,收藏留着学习. 出处:http://www.importnew.com/24822.html 代码版本 JDK每一版本都在改进.本文讨论的Hash ...

  6. 个人博客作业-Week2 (代码规范, 代码复审)

    代码规范: 1.这些规范都是官僚制度下产生的浪费大家的编程时间.影响人们开发效率, 浪费时间的东西. 编码规范它包含了代码格式,还包括了编码风格和其他规范,通常涉及:缩进.空格使用.Tab使用 注释. ...

  7. 【CV】ICCV2015_Unsupervised Visual Representation Learning by Context Prediction

    Unsupervised Visual Representation Learning by Context Prediction Note here: it's a learning note on ...

  8. Linux内核第六节 20135332武西垚

    如何描述一个进程:进程描述符的数据结构: 如何创建一个进程:内核是如何执行的,以及新创建的进程从哪里开始执行: 使用gdb跟踪新进程的创建过程. 进程的描述 操作系统三大功能: 进程管理(最核心最基础 ...

  9. SuperMaze(Hello World 团队)Alpha版使用说明

    一.产品介绍 超级迷宫是一款android的手机游戏,目前我们已经在PC 端成功实现大体功能,虽然虽然迷宫游戏不少但我们的游戏渐渐的会假如自己的特色功能,尽量吸引用户,通过游戏开发智力,通过游戏打发无 ...

  10. JavaScript中的cookie

    cookie本身没什么可介绍的,但是cookie在JavaScript中,有很多需要注意的 首先,cookie在JavaScript中,是window.document对象的一个属性,所以访问cook ...