【BZOJ4821】[SDOI2017]相关分析(线段树)

题面

BZOJ

洛谷

题解

看看询问要求的东西是什么。把所有的括号拆开,不难发现要求的就是\(\sum x,\sum y,\sum xy,\sum x^2\)

考虑修改操作。先是区间加法,对于\(\sum x,\sum y\)而言直接加就好了。

而\(\sum (x+S)^2=\sum (x^2+S^2+2Sx)\),分开维护一下也做完了。

\(\sum (x+S)(y+T)\)也只需要把括号拆开之后分开维护就行了。

另外一种是区间赋值,我们看做先令\(x_i=y_i=i\),然后再对应的加上\(S,T\)就好了。注意一下这里要把之前操作里面的\(S,T\)标记清空。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
#define MAX 100100
#define lson (now<<1)
#define rson (now<<1|1)
#define ll long long
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int n,m,X[MAX],Y[MAX];
struct Node{double x,y,xy,xx,S,T;int eql;}t[MAX<<2];
Node operator+(Node a,Node b){return (Node){a.x+b.x,a.y+b.y,a.xy+b.xy,a.xx+b.xx,0,0,0};}
void pushup(int now)
{
t[now].x=t[lson].x+t[rson].x;
t[now].y=t[lson].y+t[rson].y;
t[now].xx=t[lson].xx+t[rson].xx;
t[now].xy=t[lson].xy+t[rson].xy;
}
void Build(int now,int l,int r)
{
if(l==r)
{
t[now].x=X[l],t[now].y=Y[l];
t[now].xx=t[now].x*t[now].x;
t[now].xy=t[now].x*t[now].y;
return;
}
int mid=(l+r)>>1;
Build(lson,l,mid);Build(rson,mid+1,r);
pushup(now);
}
double S1(int x){return 0.5*x*(x+1);}
double S2(int x){return 1.0/6*x*(x+1)*(x+x+1);}
void addST(int now,int l,int r,double S,double T)
{
int len=r-l+1;
t[now].xx+=len*S*S+2*S*t[now].x;
t[now].xy+=t[now].x*T+t[now].y*S+len*S*T;
t[now].x+=len*S;t[now].y+=len*T;
t[now].S+=S;t[now].T+=T;
}
void addeql(int now,int l,int r)
{
t[now].x=t[now].y=S1(r)-S1(l-1);
t[now].xx=t[now].xy=S2(r)-S2(l-1);
t[now].eql=1;t[now].S=t[now].T=0;
}
void pushdown(int now,int l,int r)
{
int mid=(l+r)>>1;
if(t[now].eql)
{
addeql(lson,l,mid);addeql(rson,mid+1,r);
t[now].eql=0;
}
if(t[now].S||t[now].T)
{
addST(lson,l,mid,t[now].S,t[now].T);
addST(rson,mid+1,r,t[now].S,t[now].T);
t[now].S=t[now].T=0;
}
}
void Modify(int now,int l,int r,int L,int R,double S,double T)
{
if(L<=l&&r<=R){addST(now,l,r,S,T);return;}
int mid=(l+r)>>1;pushdown(now,l,r);
if(L<=mid)Modify(lson,l,mid,L,R,S,T);
if(R>mid)Modify(rson,mid+1,r,L,R,S,T);
pushup(now);
}
void Modify(int now,int l,int r,int L,int R)
{
if(L<=l&&r<=R){addeql(now,l,r);return;}#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
#define MAX 100100
#define lson (now<<1)
#define rson (now<<1|1)
#define ll long long
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int n,m,X[MAX],Y[MAX];
struct Node{double x,y,xy,xx,S,T;int eql;}t[MAX<<2];
Node operator+(Node a,Node b){return (Node){a.x+b.x,a.y+b.y,a.xy+b.xy,a.xx+b.xx,0,0,0};}
void pushup(int now)
{
t[now].x=t[lson].x+t[rson].x;
t[now].y=t[lson].y+t[rson].y;
t[now].xx=t[lson].xx+t[rson].xx;
t[now].xy=t[lson].xy+t[rson].xy;
}
void Build(int now,int l,int r)
{
if(l==r)
{
t[now].x=X[l],t[now].y=Y[l];
t[now].xx=t[now].x*t[now].x;
t[now].xy=t[now].x*t[now].y;
return;
}
int mid=(l+r)>>1;
Build(lson,l,mid);Build(rson,mid+1,r);
pushup(now);
}
double S1(int x){return 0.5*x*(x+1);}
double S2(int x){return 1.0/6*x*(x+1)*(x+x+1);}
void addST(int now,int l,int r,double S,double T)
{
int len=r-l+1;
t[now].xx+=len*S*S+2*S*t[now].x;
t[now].xy+=t[now].x*T+t[now].y*S+len*S*T;
t[now].x+=len*S;t[now].y+=len*T;
t[now].S+=S;t[now].T+=T;
}
void addeql(int now,int l,int r)
{
t[now].x=t[now].y=S1(r)-S1(l-1);
t[now].xx=t[now].xy=S2(r)-S2(l-1);
t[now].eql=1;t[now].S=t[now].T=0;
}
void pushdown(int now,int l,int r)
{
int mid=(l+r)>>1;
if(t[now].eql)
{
addeql(lson,l,mid);addeql(rson,mid+1,r);
t[now].eql=0;
}
if(t[now].S||t[now].T)
{
addST(lson,l,mid,t[now].S,t[now].T);
addST(rson,mid+1,r,t[now].S,t[now].T);
t[now].S=t[now].T=0;
}
}
void Modify(int now,int l,int r,int L,int R,double S,double T)
{
if(L<=l&&r<=R){addST(now,l,r,S,T);return;}
int mid=(l+r)>>1;pushdown(now,l,r);
if(L<=mid)Modify(lson,l,mid,L,R,S,T);
if(R>mid)Modify(rson,mid+1,r,L,R,S,T);
pushup(now);
}
void Modify(int now,int l,int r,int L,int R)
{
if(L<=l&&r<=R){addeql(now,l,r);return;}
int mid=(l+r)>>1;pushdown(now,l,r);
if(L<=mid)Modify(lson,l,mid,L,R);
if(R>mid)Modify(rson,mid+1,r,L,R);
pushup(now);
}
Node Query(int now,int l,int r,int L,int R)
{
if(l==L&&r==R)return t[now];
int mid=(l+r)>>1;pushdown(now,l,r);
if(R<=mid)return Query(lson,l,mid,L,R);
if(L>mid)return Query(rson,mid+1,r,L,R);
return Query(lson,l,mid,L,mid)+Query(rson,mid+1,r,mid+1,R);
}
int main()
{
n=read();m=read();
for(int i=1;i<=n;++i)X[i]=read();
for(int i=1;i<=n;++i)Y[i]=read();
Build(1,1,n);
while(m--)
{
int opt=read(),l=read(),r=read();
if(opt==1)
{
Node a=Query(1,1,n,l,r);
double u=a.xy-a.x*a.y/(r-l+1);
double v=a.xx-a.x*a.x/(r-l+1);
printf("%.10lf\n",u/v);
}
else
{
double S=read(),T=read();
if(opt==3)Modify(1,1,n,l,r);
Modify(1,1,n,l,r,S,T);
}
}
return 0;
} int mid=(l+r)>>1;pushdown(now,l,r);
if(L<=mid)Modify(lson,l,mid,L,R);
if(R>mid)Modify(rson,mid+1,r,L,R);
pushup(now);
}
Node Query(int now,int l,int r,int L,int R)
{
if(l==L&&r==R)return t[now];
int mid=(l+r)>>1;pushdown(now,l,r);
if(R<=mid)return Query(lson,l,mid,L,R);
if(L>mid)return Query(rson,mid+1,r,L,R);
return Query(lson,l,mid,L,mid)+Query(rson,mid+1,r,mid+1,R);
}
int main()
{
n=read();m=read();
for(int i=1;i<=n;++i)X[i]=read();
for(int i=1;i<=n;++i)Y[i]=read();
Build(1,1,n);
while(m--)
{
int opt=read(),l=read(),r=read();
if(opt==1)
{
Node a=Query(1,1,n,l,r);
double u=a.xy-a.x*a.y/(r-l+1);
double v=a.xx-a.x*a.x/(r-l+1);
printf("%.10lf\n",u/v);
}
else
{
double S=read(),T=read();
if(opt==3)Modify(1,1,n,l,r);
Modify(1,1,n,l,r,S,T);
}
}
return 0;
}

【BZOJ4821】[SDOI2017]相关分析(线段树)的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

  7. SDOI2017相关分析 线段树

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

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

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

  9. luogu3707 相关分析 (线段树)

    把式子展开以后会发现,可以用线段树维护$x,y,x*y,x^2$分别的区间和 然后操作有区间加和区间修改 这个pushdown的时候,如果改和加的标记同时存在,那一定是先改再加,要不然加的标记已经被清 ...

  10. BZOJ4821 SDOI2017相关分析(线段树)

    纯粹的码农题.维护x的和.y的和.xy的和.x2的和即可.可能会炸long long. #include<iostream> #include<cstdio> #include ...

随机推荐

  1. Luogu P4016 负载平衡问题

    传说中的网络流24题之一,我刷的第二题菜. 据说这种东西做完了就可以有质的飞越?不过看着这些Luogu评级就有点蒙蔽. 首先我们看一下题目发现这不是均分纸牌的加强板吗,但是那个环的操作极大地限制了我的 ...

  2. 【nodejs】让nodejs像后端mvc框架(asp.net mvc)一orm篇【如EF般丝滑】typeorm介绍(8/8)

    文章目录 前情概要 在使用nodejs开发过程中,刚好碰到需要做一个小工具,需要用到数据库存储功能.而我又比较懒,一个小功能不想搞一个nodejs项目,又搞一个后端项目.不如直接在nodejs里面把对 ...

  3. 阿里云Https通配符证书购买

    先付款,再绑定证书. 会款后会审核,等待... DNS解析配置错误 按域名授权配置,增加一条 DNS Txt记录值.

  4. Linux下DNS服务(Bind9)之Web管理利器-NamedManager部署说明

    NamedManager 是一个基于Web的DNS管理系统,可用来添加.调整和删除DNS的zones/records数据.它使用Bind作为底层DNS服务,提供一个现代Ajax的Web界面,支持 IP ...

  5. Centos7.3下安装Jumpserver 1.0.0(支持windows组件)

    Jumpserver最新版本支持windows组件,废话不多介绍了,下面直接介绍下部署过程: 0)系统环境 CentOS 7.3 IP: 192.168.10.210 [root@jumpserver ...

  6. 20135337——实践一:Linux基础配置

    一.配置系统,权限中简单梳理遇到的问题 1.Ubuntu中root和普通用户相互切换 1.从user用户切换到root用户 执行:sudo su 2.从root用户切回user用户 执行:su use ...

  7. 安装python包时报错

    pip install numpy  时  报错: Traceback (most recent call last):  File "d:\学习\python\python-3.6.5\l ...

  8. Quartz.NET 入门,带C#实例

    概述 Quartz.NET是一个开源的作业调度框架,非常适合在平时的工作中,定时轮询数据库同步,定时邮件通知,定时处理数据等. Quartz.NET允许开发人员根据时间间隔(或天)来调度作业.它实现了 ...

  9. SSM(Spring +SpringMVC + Mybatis)框架搭建

    SSM(Spring +SpringMVC + Mybatis)框架的搭建 最近通过学习别人博客发表的SSM搭建Demo,尝试去搭建一个简单的SSMDemo---实现的功能是对用户增删改查的操作 参考 ...

  10. CI框架2.x的验证码中所遇问题解决

    用php版本是5.6,CI框架版本是2.x,在使用验证码(captcha)时,遇到一些问题. 首先,我查看框架手册,说必需的两个参数是"img_url",“img_path”,其他 ...