【题解】Luogu P1471 方差
原题传送门
简单进行推导之后,就能发现很妙的结论
用线段树维护区间和,区间平方和就珂以算出结果
#include <bits/stdc++.h>
#define db double
#define N 100005
using namespace std;
int n,m;
db a[N];
db sum1[N<<3],sum2[N<<3],tag[N<<3];
inline void pushup(register int x)
{
sum1[x]=sum1[x<<1]+sum1[x<<1|1];
sum2[x]=sum2[x<<1]+sum2[x<<1|1];
}
inline void build(register int x,register int l,register int r)
{
if(l==r)
{
sum1[x]=a[l],sum2[x]=a[l]*a[l];
return;
}
int mid=l+r>>1;
build(x<<1,l,mid),build(x<<1|1,mid+1,r);
pushup(x);
}
inline void pushdown(register int x,register int l,register int r)
{
int ls=x<<1,rs=x<<1|1,mid=l+r>>1;
sum2[ls]+=2*tag[x]*sum1[ls]+(mid-l+1)*tag[x]*tag[x];
sum2[rs]+=2*tag[x]*sum1[rs]+(r-mid)*tag[x]*tag[x];
sum1[ls]+=tag[x]*(mid-l+1),sum1[rs]+=tag[x]*(r-mid);
tag[ls]+=tag[x],tag[rs]+=tag[x];
tag[x]=0;
}
inline void update(register int x,register int l,register int r,register int L,register int R,register db v)
{
if(L<=l&&r<=R)
{
tag[x]+=v,sum2[x]+=2*v*sum1[x]+v*v*(r-l+1),sum1[x]+=v*(r-l+1);
return;
}
if(tag[x])
pushdown(x,l,r);
int mid=l+r>>1;
if(L<=mid)
update(x<<1,l,mid,L,R,v);
if(R>mid)
update(x<<1|1,mid+1,r,L,R,v);
pushup(x);
}
inline db query1(register int x,register int l,register int r,register int L,register int R)
{
if(L<=l&&r<=R)
return sum1[x];
if(tag[x])
pushdown(x,l,r);
db res=0;
int mid=l+r>>1;
if(L<=mid)
res+=query1(x<<1,l,mid,L,R);
if(R>mid)
res+=query1(x<<1|1,mid+1,r,L,R);
return res;
}
inline db query2(register int x,register int l,register int r,register int L,register int R)
{
if(L<=l&&r<=R)
return sum2[x];
if(tag[x])
pushdown(x,l,r);
db res=0;
int mid=l+r>>1;
if(L<=mid)
res+=query2(x<<1,l,mid,L,R);
if(R>mid)
res+=query2(x<<1|1,mid+1,r,L,R);
return res;
}
int main()
{
scanf("%d%d",&n,&m);
for(register int i=1;i<=n;++i)
cin>>a[i];
build(1,1,n);
while(m--)
{
int opt;
scanf("%d",&opt);
if(opt==1)
{
int l,r;
scanf("%d%d",&l,&r);
db v;
cin>>v;
update(1,1,n,l,r,v);
}
else if(opt==2)
{
int l,r;
scanf("%d%d",&l,&r);
db ans=query1(1,1,n,l,r)/(r-l+1);
printf("%.4lf\n",ans);
}
else
{
int l,r;
scanf("%d%d",&l,&r);
db a=query2(1,1,n,l,r)/(r-l+1),b=query1(1,1,n,l,r)/(r-l+1);
db ans=a-b*b;
printf("%.4lf\n",ans);
}
}
return 0;
}
【题解】Luogu P1471 方差的更多相关文章
- Luogu P1471 方差
题目传送门 开了十倍空间才过是什么鬼?该不会我线段树炸了吧-- 细思极恐 平均数都会求,维护区间和,到时候除一下就好了. 方差的求法如下 (用的Luogu的图片) 因为要维护一个平方,我们可以考虑使用 ...
- Luogu P1471 方差 线段树
那是上上周...也是重构了四遍...后来GG了...今天又拾起,搞了搞终于过了... 好吧就是个线段树,公式懒得推了https://www.cnblogs.com/Jackpei/p/10693561 ...
- 洛谷 P1471 方差
洛谷 P1471 方差 题目背景 滚粗了的HansBug在收拾旧数学书,然而他发现了什么奇妙的东西. 题目描述 蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的 ...
- 【洛谷】【线段树】P1471 方差
[题目背景:] 滚粗了的HansBug在收拾旧数学书,然而他发现了什么奇妙的东西. [题目描述:] 蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的平均数和方差 ...
- 洛谷——P1471 方差
P1471 方差 题目描述 蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的平均数和方差. 借一下远航之曲大佬的图片,特别清晰: 那么只要维护区间平方和,就可以 ...
- [题解] Luogu P5446 [THUPC2018]绿绿和串串
[题解] Luogu P5446 [THUPC2018]绿绿和串串 ·题目大意 定义一个翻转操作\(f(S_n)\),表示对于一个字符串\(S_n\), 有\(f(S)= \{S_1,S_2,..., ...
- 【luogu P1471】方差
https://www.luogu.org/problem/show?pid=1471 一眼就能看出是线段树/树状数组题目了. 求平均不用说,线段树/树状数组维护区间和即可. 方差怎么求?先变换下方差 ...
- 洛谷P1471 方差
蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的平均数和方差. ——by 洛谷; http://www.luogu.org/problem/show?pid=1 ...
- 题解 Luogu P2499: [SDOI2012]象棋
关于这道题, 我们可以发现移动顺序不会改变答案, 具体来说, 我们有以下引理成立: 对于一个移动过程中的任意一个移动, 若其到达的位置上有一个棋子, 则该方案要么不能将所有棋子移动到最终位置, 要么可 ...
随机推荐
- CSP201312-4 有趣的数【dp】
问题描述 试题编号: 201312-4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, ...
- Dynamics 365 解决方案导出报错
之前导出解决方案异常,按照CRM社区的方法解决成功,但是没有了解原因,今天看到有朋友解答了原因,也分享给大家 先来看看异常 我那时导出的是default解决方案,这是模拟 导出异常 “业务流程错误”- ...
- vim删除.swp
非正常关闭vi编辑器时会生成一个.swp文件 关于swp文件 使用vi,经常可以看到swp这个文件,那这个文件是怎么产生的呢,当你打开一个文件,vi就会生成这么一个.(filename)swp文件以备 ...
- [daily] emacs显示file name buffer的全路径
在用emacs看代码的时候,在文件间跳来跳去,如果工程太大的话,很可能会有重名文件,这个时候, 你就不知道自己在什么的地方了.需要一个查看当前正在编辑区的文件的名字的方法. emacs在这个地方,存储 ...
- linux-rhel7配置网卡bond双网卡主备模式
参考以下文章中的 2.centos7配置bonding: https://www.cnblogs.com/huangweimin/articles/6527058.html 以下是配置过程的操作和打印 ...
- atmega16功耗实测
晶振32.768K 电压 电流 1.82 10ua 2.00 15ua 2.5 28ua 3.3 ...
- python写算法中的栈
########### 栈的使用 ############### class StackFullError(Exception): pass class StackEmptyError(Excepti ...
- 设置js的ctx
<script type="text/javascript" src="${ctx}/js/dynamic.jsp"></script> ...
- Python从入坑到放弃!
Python基础 python基础 python基础之 while 逻辑运算符 格式化输出等 python基础之 基本数据类型,str方法和for循环 python基础之 列表,元组,字典 pyth ...
- vi命令撤销及恢复
u :插销上一步操作 Ctrl + r :恢复被撤销的上一步操作