AC日记——方差 洛谷 P1471
思路:
线段树;
代码:
#include <bits/stdc++.h>
using namespace std;
#define maxn 100005
struct TreeNodeType {
int l,r,mid,size;
double sum,sum2,flag;
inline void updata(double x)
{
flag+=x;
sum2+=sum*x*+size*x*x;
sum+=x*size;
}
};
struct TreeNodeType tree[maxn<<];
int n,m;
double X,Sum,Sum2;
inline void in(int &now)
{
int if_z=;now=;
char Cget=getchar();
while(Cget>''||Cget<'')
{
if(Cget=='-') if_z=-;
Cget=getchar();
}
while(Cget>=''&&Cget<='')
{
now=now*+Cget-'';
Cget=getchar();
}
now*=if_z;
}
void build(int now,int l,int r)
{
tree[now].l=l,tree[now].r=r,tree[now].size=r-l+;
if(l==r)
{
scanf("%lf",&tree[now].sum);
tree[now].sum2=tree[now].sum*tree[now].sum;
return;
}
tree[now].mid=l+r>>;
build(now<<,l,tree[now].mid);
build(now<<|,tree[now].mid+,r);
tree[now].sum=tree[now<<].sum+tree[now<<|].sum;
tree[now].sum2=tree[now<<].sum2+tree[now<<|].sum2;
}
inline void pushdown(int now)
{
tree[now<<].updata(tree[now].flag);
tree[now<<|].updata(tree[now].flag);
tree[now].flag=;
}
void operation1(int now,int l,int r)
{
if(tree[now].l>=l&&tree[now].r<=r)
{
tree[now].updata(X);
return;
}
if(tree[now].flag) pushdown(now);
if(l<=tree[now].mid) operation1(now<<,l,r);
if(r>tree[now].mid) operation1(now<<|,l,r);
tree[now].sum=tree[now<<].sum+tree[now<<|].sum;
tree[now].sum2=tree[now<<].sum2+tree[now<<|].sum2;
}
void operation2(int now,int l,int r)
{
if(tree[now].l>=l&&tree[now].r<=r)
{
Sum+=tree[now].sum;
Sum2+=tree[now].sum2;
return;
}
if(tree[now].flag) pushdown(now);
if(l<=tree[now].mid) operation2(now<<,l,r);
if(r>tree[now].mid) operation2(now<<|,l,r);
}
int main()
{
in(n),in(m),build(,,n);
int op,l,r;
while(m--)
{
in(op),in(l),in(r);
if(op==) scanf("%lf",&X),operation1(,l,r);
if(op==) Sum=,operation2(,l,r),printf("%.4lf\n",Sum/(r-l+));
if(op==)
{
Sum=,Sum2=;
operation2(,l,r);
X=Sum/(r-l+);
printf("%.4lf\n",(Sum2-Sum*X*+(r-l+)*X*X)/(r-l+));
}
}
return ;
}
AC日记——方差 洛谷 P1471的更多相关文章
- AC日记——最大数 洛谷 P1198 [JSOI2008]
		
题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超过当前数列的长度. 2. 插入操作 ...
 - AC日记——中位数 洛谷 P1168
		
题目描述 给出一个长度为N的非负整数序列A[i],对于所有1 ≤ k ≤ (N + 1) / 2,输出A[1], A[2], …, A[2k - 1]的中位数.[color=red]即[/color] ...
 - AC日记——传染病控制 洛谷 P1041
		
传染病控制 思路: 题目想问的是: 有一棵树: 对于除1外每个深度可以剪掉一棵子树: 问最后剩下多少节点: 题目意思一简单,这个题立马就变水了: 搜索就能ac: 数据有为链的情况,按深度为层次搜索的话 ...
 - AC日记——忠诚 洛谷 P1816
		
题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人的挑拨,财主还是对管家产生了 ...
 - AC日记——独木桥 洛谷 p1007
		
题目背景 战争已经进入到紧要时间.你是运输小队长,正在率领运输部队向前线运送物资.运输任务像做题一样的无聊.你希望找些刺激,于是命令你的士兵们到前方的一座独木桥上欣赏风景,而你留在桥下欣赏士兵们.士兵 ...
 - AC日记——潜伏者 洛谷 P1071 (模拟)
		
题目描述 R 国和 S 国正陷入战火之中,双方都互派间谍,潜入对方内部,伺机行动.历尽艰险后,潜伏于 S 国的 R 国间谍小 C 终于摸清了 S 国军用密码的编码规则: 1. S 国军方内部欲发送的原 ...
 - AC日记——机器翻译 洛谷 P1540
		
题目背景 小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章. 题目描述 这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换.对于每个英文单词,软件会先 ...
 - AC日记——统计和 洛谷 P2068
		
统计和 思路: 水题: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 100005 int n,m,tree ...
 - AC日记——送花 洛谷 P2073
		
送花 思路: 线段树: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 100005 struct TreeN ...
 
随机推荐
- js正则表达式,判断字符串是否以数字组结尾,并取出结尾的数字
			
js正则表达式,判断字符串是否以数字组结尾,并取出结尾的数字 <!DOCTYPE html> <html> <head> <meta charset=&quo ...
 - HDU1083 :Courses(二分图匹配)
			
Cources Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
 - 题解 【luogu P2680 NOIp提高组2015 运输计划】
			
题目链接 题解 题意 一棵树上有\(m\)条路径,可以将其中一条边的权值改为0,问最长的路径最短是多少 分析 最短的路径最长自然想到二分最长路径,设其为\(dis\) 关键在于如何check chec ...
 - NYOJ 737DP
			
石子合并(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 有N堆石子排成一排,每堆石子有一定的数量.现要将N堆石子并成为一堆.合并的过程只能每次将相邻的 ...
 - div模拟textarea在ios下不兼容的问题解决
			
今天发现一个好东西,赶紧记下来,我在用textarea的时候,想要自适应高度,这样就不会出现滚动条.网上找了很多,都是用div模拟的,但是好扯淡,div模拟的在ios下不能聚焦并且不能输入.真坑... ...
 - 20155335俞昆《java程序设计》第三周总结
			
20155335 2006-2007-2 <Java程序设计>第三周学习总结 ## 教材学习内容总结 首先,关键是区基本类型和类类型,,产生对象必须定义类,类是一个概念,并不存在,对 ...
 - bzoj 3035 二分答案+二分图最大匹配
			
大原来做的一道题,偷懒直接粘的原来的程序 http://www.cnblogs.com/BLADEVIL/p/3433520.html /******************************* ...
 - window对象的方法和属性汇总
			
window对象有以下方法: open close alert confirm prompt setTimeout clearTimeout setInterval clearInterval mov ...
 - Java 将html导出word格式
			
@RequestMapping("download") public void exportWord( HttpServletRequest request, HttpServle ...
 - 自定义ToolBar
			
一.Toolbar的简介 Toolbar 是 android 5.0 引入的一个新控件,Toolbar出现之前,我们很多时候都是使用ActionBar以及ActionActivity实现顶部导航栏的, ...