【Luogu1471】方差(线段树)

题面

这种傻逼题。。。自己去看把。。

题解

这题太傻比了

把方差公式拆开

维护平方和和区间和

修改就把平方和的公式拆开

简直傻逼的题目

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define MAX 150000
#define lson (now<<1)
#define rson (now<<1|1)
struct Node
{
double s,ps;
double ly;
}t[MAX<<4];
double a[MAX];
int n,m;
void Build(int now,int l,int r)
{
if(l==r)
{
t[now].s=a[l];
t[now].ps=a[l]*a[l];
return;
}
int mid=(l+r)>>1;
Build(lson,l,mid);Build(rson,mid+1,r);
t[now].s=t[lson].s+t[rson].s;
t[now].ps=t[lson].ps+t[rson].ps;
}
void pushdown(int now,int l,int r)
{
double k=t[now].ly;
int mid=(l+r)>>1;
t[lson].ly+=k;
t[rson].ly+=k;
t[lson].ps+=2*t[lson].s*k+(mid-l+1)*k*k;
t[rson].ps+=2*t[rson].s*k+(r-mid)*k*k;
t[lson].s+=(mid-l+1)*k;
t[rson].s+=(r-mid)*k;
t[now].ly=0;
}
void putlazy(int now,int l,int r,double k)
{
t[now].ly+=k;
t[now].ps+=2*t[now].s*k+(r-l+1)*k*k;
t[now].s+=(r-l+1)*k;
}
void Modify(int now,int l,int r,int L,int R,double w)
{
if(L<=l&&r<=R){putlazy(now,l,r,w);return;}
pushdown(now,l,r);
int mid=(l+r)>>1;
if(L<=mid)Modify(lson,l,mid,L,R,w);
if(R>mid)Modify(rson,mid+1,r,L,R,w);
t[now].ps=t[lson].ps+t[rson].ps;
t[now].s=t[lson].s+t[rson].s;
}
double Query1(int now,int l,int r,int L,int R)
{
if(L<=l&&r<=R)return t[now].s;
pushdown(now,l,r);
double ret=0;
int mid=(l+r)>>1;
if(L<=mid)ret+=Query1(lson,l,mid,L,R);
if(R>mid)ret+=Query1(rson,mid+1,r,L,R);
return ret;
}
double Query2(int now,int l,int r,int L,int R)
{
if(L<=l&&r<=R)return t[now].ps;
pushdown(now,l,r);
double ret=0;
int mid=(l+r)>>1;
if(L<=mid)ret+=Query2(lson,l,mid,L,R);
if(R>mid)ret+=Query2(rson,mid+1,r,L,R);
return ret;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)scanf("%lf",&a[i]);
Build(1,1,n);
int opt,ll,rr;
double kk;
while(m--)
{
scanf("%d%d%d",&opt,&ll,&rr);
if(opt==1)
{
scanf("%lf",&kk);
Modify(1,1,n,ll,rr,kk);
}
else if(opt==2)
{
double ret=Query1(1,1,n,ll,rr);
printf("%.4lf\n",ret/(rr-ll+1));
}
else
{
double c1=Query1(1,1,n,ll,rr);
double c2=Query2(1,1,n,ll,rr);
double c3=c1/(rr-ll+1);
double ans=c2-2*c1*c3+(rr-ll+1)*c3*c3;
printf("%.4lf\n",ans/(rr-ll+1));
}
}
return 0;
}

最新文章

  1. [示例] Firemonkey OnTouch 多点触控应用
  2. IOS数据存储之CoreData使用优缺点
  3. 2. Docker - 安装
  4. section和article元素
  5. JAVA OOP 基础知识提纲
  6. std::reverse_iterator::base
  7. 最小化安装Centos7后的部署(个人)
  8. 字符串模式匹配sunday算法
  9. Html的空格显示
  10. Android 应用页面延缓载入
  11. Java中迭代列表中数据时几种循环写法的效率比较
  12. linux vim 常用命令
  13. javaTemplates-学习笔记一
  14. Objective C (iOS) for Qt C++ Developers(iOS开发,Qt开发人员需要了解什么?)
  15. Managing Spark data handles in R
  16. django关闭调试信息,打开内置错误视图
  17. cygwin 下安装python MySQLdb
  18. Web中的积累:外观模式 Facade
  19. 第一册:lesson thirty three。
  20. Codeforces Round #313 (Div. 2) C. Gerald&amp;#39;s Hexagon(补大三角形)

热门文章

  1. SQL Server 页面查询超时(SOS_SCHEDULER_YIELD等待)
  2. JMETER_16个逻辑控制器详解
  3. Rsync(远程同步): linux中Rsync命令的实际示例
  4. angular2^ typescript 将 文件和Json数据 合并发送到服务器(2.服务端)
  5. 【学习笔记】Hibernate 一对一关联映射 组件映射 二级缓存 集合缓存
  6. Linux常用命令详解(一) -- 处理目录常用命令
  7. node.js简单搭建服务,访问本地站点文件
  8. JS标签的各种事件的举例
  9. [翻译] .NET Core 2.1 Preview 1 发布
  10. 原创:实现ehcache动态创建cache,以及超期判断的具体逻辑