[bzoj4821][Sdoi2017]相关分析
来自FallDream的博客,未经允许,请勿转载,谢谢。
#include<iostream>
#include<cstdio>
#define MN 100000
#define ld long double
using namespace std;
inline int read()
{
int x = , f = ; char ch = getchar();
while(ch < '' || ch > ''){ if(ch == '-') f = -; ch = getchar();}
while(ch >= '' && ch <= ''){x = x * + ch - '';ch = getchar();}
return x * f;
} struct data{ld x,y,sqx,xy;
friend data operator + (data a,data b)
{
return (data){a.x+b.x,a.y+b.y,a.sqx+b.sqx,a.xy+b.xy};
}
}res;
struct Mark{int op,s,t;}M[MN+];
struct Tree{int l,r,tag;ld s,t;data x;}T[MN*+];
int n,m,X[MN+],Y[MN+],tms=;
void build(int x,int l,int r)
{
if((T[x].l=l)==(T[x].r=r))
{
T[x].x=(data){X[l],Y[l],(ld)X[l]*X[l],(ld)X[l]*Y[l]};
return;
}
int mid=l+r>>;
build(x<<,l,mid);build(x<<|,mid+,r);
T[x].x=T[x<<].x+T[x<<|].x;
}
inline ld Sum(int x){return (ld)x*(x+)/;}
inline ld Sqr(int x){return (ld)x*(x+)*(*x+)/;}
void _Mark(int x,int op,int s,int t)
{
if(op==){T[x].tag=;T[x].s=s;T[x].t=t;}
else if(T[x].tag) T[x].s+=s,T[x].t+=t;
else T[x].tag=,T[x].s=s,T[x].t=t;
if(op==)
{
T[x].x.sqx+=(ld)*s*T[x].x.x+(ld)(T[x].r-T[x].l+)*s*s;
T[x].x.xy+=(ld)s*T[x].x.y+(ld)t*T[x].x.x+(ld)(T[x].r-T[x].l+)*s*t;
T[x].x.x+=(ld)(T[x].r-T[x].l+)*s;
T[x].x.y+=(ld)(T[x].r-T[x].l+)*t;
}
else
{
T[x].x.x=Sum(T[x].r)-Sum(T[x].l-)+(ld)(T[x].r-T[x].l+)*s;
T[x].x.y=Sum(T[x].r)-Sum(T[x].l-)+(ld)(T[x].r-T[x].l+)*t;
T[x].x.sqx=(ld)(T[x].r-T[x].l+)*s*s+Sqr(T[x].r)-Sqr(T[x].l-)+(ld)*s*(Sum(T[x].r)-Sum(T[x].l-));
T[x].x.xy=(ld)(T[x].r-T[x].l+)*s*t+(ld)(s+t)*(Sum(T[x].r)-Sum(T[x].l-))+Sqr(T[x].r)-Sqr(T[x].l-);
}
} void pushdown(int x)
{
if(T[x].tag)
{
int l=x<<,r=l|;
_Mark(l,T[x].tag,T[x].s,T[x].t);
_Mark(r,T[x].tag,T[x].s,T[x].t);
T[x].tag=;
}
} void Modify(int x,int l,int r,int op)
{
if(T[x].l==l&&T[x].r==r)
{
_Mark(x,M[op].op,M[op].s,M[op].t);
return;
}
pushdown(x);
int mid=T[x].l+T[x].r>>;
if(r<=mid) Modify(x<<,l,r,op);
else if(l>mid) Modify(x<<|,l,r,op);
else Modify(x<<,l,mid,op),Modify(x<<|,mid+,r,op);
T[x].x=T[x<<].x+T[x<<|].x;
} void Query(int x,int l,int r)
{
if(T[x].l==l&&T[x].r==r){res=res+T[x].x;return;}
pushdown(x);
int mid=T[x].l+T[x].r>>;
if(r<=mid) Query(x<<,l,r);
else if(l>mid) Query(x<<|,l,r);
else Query(x<<,l,mid),Query(x<<|,mid+,r);
} main()
{
n=read();m=read();
for(int i=;i<=n;++i)X[i]=read();
for(int i=;i<=n;++i)Y[i]=read();
build(,,n);
for(int i=;i<=m;++i)
{
int op=read(),l=read(),r=read();
if(op==)
{
res=(data){,,,};Query(,l,r);
ld _x=(ld)res.x/(r-l+),_y=(ld)res.y/(r-l+);
ld u=res.xy-_x*res.y-_y*res.x+_x*_y*(r-l+);
ld d=res.sqx-*_x*res.x+_x*_x*(r-l+);
printf("%.8lf\n",(double)u/(double)d);
}
else
{
int s=read(),t=read();
M[i]=(Mark){op,s,t};
Modify(,l,r,i);
}
}
return ;
}
[bzoj4821][Sdoi2017]相关分析的更多相关文章
- BZOJ4821 SDOI2017相关分析(线段树)
纯粹的码农题.维护x的和.y的和.xy的和.x2的和即可.可能会炸long long. #include<iostream> #include<cstdio> #include ...
- 【BZOJ4821】[SDOI2017]相关分析(线段树)
[BZOJ4821][SDOI2017]相关分析(线段树) 题面 BZOJ 洛谷 题解 看看询问要求的东西是什么.把所有的括号拆开,不难发现要求的就是\(\sum x,\sum y,\sum xy,\ ...
- 【BZOJ4821】[Sdoi2017]相关分析 线段树
[BZOJ4821][Sdoi2017]相关分析 Description Frank对天文学非常感兴趣,他经常用望远镜看星星,同时记录下它们的信息,比如亮度.颜色等等,进而估算出星星的距离,半径等等. ...
- BZOJ4817 SDOI2017 相关分析
4821: [Sdoi2017]相关分析 Time Limit: 10 Sec Memory Limit: 128 MBSec Special Judge Description Frank对天文 ...
- [Sdoi2017]相关分析 [线段树]
[Sdoi2017]相关分析 题意:沙茶线段树 md其实我考场上还剩一个多小时写了40分 其实当时写正解也可以吧1h也就写完了不过还要拍一下 正解代码比40分短2333 #include <io ...
- [题目] Luogu P3707 [SDOI2017]相关分析
参考资料:[Luogu 3707] SDOI2017 相关分析 P3707 [SDOI2017]相关分析 TFRAC FRAC DFRAC \(\tfrac{\sum}{1}\) \(\frac{\s ...
- [Luogu 3707] SDOI2017 相关分析
[Luogu 3707] SDOI2017 相关分析 前言 Capella 和 Frank 一样爱好天文学. 她常在冬季的夜晚,若有所思地望着东北方上空的五边形中,最为耀眼的一个顶点. 那一抹金黄曾带 ...
- 4821: [Sdoi2017]相关分析
4821: [Sdoi2017]相关分析 链接 分析: 大力拆式子,化简,然后线段树.注意精度问题与爆longlong问题. 代码: #include<cstdio> #include&l ...
- P3707 [SDOI2017]相关分析
P3707 [SDOI2017]相关分析 线段树裸题?但是真的很麻烦QAQ 题目给的式子是什么不用管,大力拆开,就是\(\frac{\sum x_iy_i-\overline xy_i-\overli ...
随机推荐
- django搭建web (四) models.py
demo 该demo模型主要是用于问题,选择单个或多个答案的问卷形式应用 # -*- coding: utf-8 -*- from __future__ import unicode_literals ...
- new malloc和delete free 的区别
今天看了一个面试题:问new 和 malloc, delete 和 free 的区别,扭捏了半天,也没说完全:现总结如下: 1.先看看new 和 delete 看一个例子: <span styl ...
- 将数组写入Plist文件中
-(void)writeToPlist:(NSArray *)uploadingfiles Name:(NSString *)name { NSMutableArr ...
- BizTalk 2016 配置 RosettaNet遇到的坑
本文只针对已经安装好BizTalk 2016 需要在安装RosettaNet加速器的伙伴. IIS配置 权限问题 错误信息 Failed to get IIS metabase property. E ...
- ASP.NET Web API编程——模型验证与绑定
1.模型验证 使用特性约束模型属性 可以使用System.ComponentModel.DataAnnotations提供的特性来限制模型. 例如,Required特性表示字段值不能为空,Range特 ...
- 英语日常词汇:living-room、dining-room vs dining hall
hall 大厅 : living room起居室,客厅 : dining room餐厅.饭厅 dining room是家里的客厅,比较小啊,dining hall一般指酒店或宾馆啊什么的的大厅,宴客厅
- angular2 学习笔记 ( 状态管理 state management )
更新 : 2017-12-29 ng5 移除 zone.js https://zhuanlan.zhihu.com/p/29577461 zone 的用途就是拦截游览器事件, 比如 click, a ...
- C++中构造函数的初始化列表(const、引用&变量初始化)
1. 构造函数执行分为两个阶段: a.初始化阶段(初始化) 初始化阶段具体指的是用构造函数初始化列表方式来初始化类中的数据成员. ClassXX:val(a),key(b){}; b.普通计算阶段(赋 ...
- hdu-1237 简单计算器---中缀表达式转后缀表达式
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1237 题目大意: 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. 思路 ...
- SQL Server 2014 HADR_DATABASE_WAIT_FOR_TRANSITION_TO_VERSIONING 等待
最近有发现SAP 的MES系统上了AlwaysOn后辅助节点发现无法查询的情况,例如在辅助节点上执行: SELECT TOP 0 * FROM TABLE1; 语句执行正常SELECT TOP 1* ...