CF895 E. Eyes Closed(线段树 期望)
题意

Sol
今天考试的T3,,我本来留了一个小时去写。但是T2一刚就刚了两个小时
最后也没来的及写。。
然后考完 开始写,,25min就A了。。
感觉自己太高估自己的思维,太低估自己的码力了。。。
这题比较简单吧
期望的和等于和的期望
然后线段树维护每个节点的值就可以了
交换的时候分自己不变和变成哪个数讨论一下
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
#include<vector>
#include<set>
#include<queue>
#include<cmath>
#include<iostream>
#define Pair pair<int, int>
#define MP(x, y) make_pair(x, y)
#define fi first
#define se second
#define ls k << 1
#define rs k << 1 | 1
#define int long long
#define LL long long
//#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1<<22, stdin), p1 == p2) ? EOF : *p1++)
//char buf[(1 << 22)], *p1 = buf, *p2 = buf;
using namespace std;
const int MAXN = 1e6 + , INF = 1e9 + , mod = 1e9 + ;
const double eps = 1e-;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int N, Q;
struct Node {
int l, r, siz;
double sum, mul, add;
}T[MAXN];
int a[MAXN];
void pr(int k, int son) {
T[son].sum *= T[k].mul;
T[son].sum += T[son].siz * (T[k].add);
T[son].mul *= T[k].mul;
T[son].add *= T[k].mul;
T[son].add += T[k].add;
}
void pushdown(int k) {
if(T[k].mul == && T[k].add == ) return ;
pr(k, ls); pr(k, rs);
T[k].mul = ; T[k].add = ;
}
void update(int k) {
T[k].sum = T[ls].sum + T[rs].sum;
}
void Build(int k, int ll, int rr) {
T[k].siz = rr - ll + ; T[k].l = ll; T[k].r = rr; T[k].mul = ;
if(ll == rr) {
T[k].sum = a[ll];
return ;
}
int mid = (ll + rr) >> ;
Build(ls, ll, mid); Build(rs, mid + , rr);
update(k);
}
void IntervalMul(int k, int ll, int rr, double val) {
if(ll <= T[k].l && T[k].r <= rr) {
T[k].sum *= val; T[k].mul *= val; T[k].add *= val;
return ;
}
pushdown(k);
int mid = T[k].l + T[k].r >> ;
if(ll <= mid) IntervalMul(ls, ll, rr, val);
if(rr > mid) IntervalMul(rs, ll, rr, val);
update(k);
}
void IntervalAdd(int k, int ll, int rr, double val) {
if(ll <= T[k].l && T[k].r <= rr) {
T[k].sum += T[k].siz * val; T[k].add += val;
return ;
}
pushdown(k);
int mid = T[k].l + T[k].r >> ;
if(ll <= mid) IntervalAdd(ls, ll, rr, val);
if(rr > mid) IntervalAdd(rs, ll, rr, val);
update(k);
}
double Query(int k, int ll, int rr) {
double ans = ;
if(ll <= T[k].l && T[k].r <= rr) {
ans += T[k].sum; return ans;
}
pushdown(k);
int mid = T[k].l + T[k].r >> ;
if(ll <= mid) ans += Query(ls, ll, rr);
if(rr > mid) ans += Query(rs, ll, rr);
return ans;
}
main() {
N = read(); Q = read();
for(int i = ; i <= N; i++) a[i] = read();
Build(, , N);
while(Q--) {
int opt = read();
if(opt == ) {
int l1 = read(), r1 = read(), l2 = read(), r2 = read();
double d1 = Query(, l1, r1);
double d2 = Query(, l2, r2), len1 = r1 - l1 + , len2 = r2 - l2 + ;
IntervalMul(, l1, r1, (len1 - ) / len1 ); IntervalMul(, l2, r2, (len2 - ) / len2);
IntervalAdd(, l1, r1, d2 / len1 / len2); IntervalAdd(, l2, r2, d1 / len1 / len2);
} else {
int l = read(), r = read();
printf("%.10lf\n", Query(, l, r));
}
}
return ;
}
CF895 E. Eyes Closed(线段树 期望)的更多相关文章
- [CF895E] Eyes Closed(线段树,期望)
Desctiption 传送门:Portal 大致题意: 给你一个序列, 支持两种操作: 1 l1 r1 l2 y2 在\([l1, r1]\)随机选择一个数a, \([l2, r2]\) 内随机选择 ...
- BZOJ 2752: [HAOI2012]高速公路(road) [线段树 期望]
2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1219 Solved: 446[Submit] ...
- JZYZOJ1527 [haoi2012]高速公路 线段树 期望
http://172.20.6.3/Problem_Show.asp?id=1527 日常线段树的pushdown写挂,果然每次写都想得不全面,以后要注意啊……求期望部分也不熟练,和平均数搞混也是or ...
- BZOJ2752: [HAOI2012]高速公路(road)(线段树 期望)
Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1820 Solved: 736[Submit][Status][Discuss] Descripti ...
- BZOJ 4262 线段树+期望
思路: 把询问离线下来,查询max和查询min相似,现在只考虑查询max 令sum[l,r,x]表示l到r内的数为左端点,x为右端点的区间询问的答案 那么询问就是sun[l1,r1,r2]-sum[l ...
- 洛谷P3924 康娜的线段树(期望 前缀和)
题意 题目链接 Sol 思路就是根据期望的线性性直接拿前缀和算贡献.. 这题输出的时候是不需要约分的qwq 如果你和我一样为了AC不追求效率的话直接#define int __int128就行了.. ...
- Codeforces 895E Eyes Closed(线段树)
题目链接 Eyes Closed 题意 两个人玩一个游戏,现在有两种操作: 1.两个人格子挑选一个区间,保证两个的区间不相交.在这两个区间里面各选出一个数,交换这两个数. 2.挑选一个区间,求这个 ...
- P3924 康娜的线段树(期望)
P3924 康娜的线段树 看起来$O(nlogn)$可过其实由于巨大常数是无法通过的 $O(nlogn)$:70pts 我们手玩样例发现 线段树上某个节点的期望值$f[o]=(f[lc]+f[rc]) ...
- hdu-5805 NanoApe Loves Sequence(线段树+概率期望)
题目链接: NanoApe Loves Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/131072 ...
随机推荐
- Exception in thread “main” java.sql.SQLException: The server time zone value ‘�й���ʱ��’ is unrecognized or represents more than one time zone.
Exception in thread “main” java.sql.SQLException: The server time zone value ‘�й���ʱ��’ is unrecogn ...
- java.lang.NoSuchMethodException: com.sun.proxy.$Proxy
删掉了@Transactional注解,结果成功了 是这个注解造成的. 是ssh2的整合强制我们使用分层架构.
- 洛谷P1073最优贸易——双向取值
题目:https://www.luogu.org/problemnew/show/P1073 由于任何城市都可以多次经过,所以可以随便走,也就不用太在意有向边和无向边,把无向边当做两条有向边处理: 根 ...
- 多叉树结构:JSON数据解析(二)
多叉树结构:JSON数据解析(二) 在上篇文章中提到了JSON数据解析的基本方法,但是方法效率太低,这里接着上篇文章写写如何利用多叉树结构,定义对象,实现JSON数据字段快速随机访问. JSON数据通 ...
- 【Linux学习】Linux系统管理1—进程管理
Linux系统管理1-进程管理 一.Linux的三种进程 Linux包括3中不同类型的进程: 交互进程:由一个shell启动的进程.交互进程可以在前后台运行 批处理进程:该进程和终端无联系,是一个进程 ...
- 大将军UE分析
1.过关奖励,先播放特效,在显示奖励 2.鼠标移到人物身上装备,提示双击卸载 3.战场随机事件,出发开启增加buff 4.主线任务简单化,副本支线可玩性增强 5.乌泱泱几十个活动 6.升级的爽快感[升 ...
- pytest入门学习(1)
系统ubuntu 12.04 , 可上网 一.安装: 1.安装 setuptools 下载页面:https://bitbucket.org/pypa/setuptools/get/default.ta ...
- Java基础 使用Properties类
- VLAN-2-私有VLAN
好的设计方式通常要求工程师为每个vlan使用一个ip子网.然而在有些情况下,将设备分割到许多小VLAN中以增加安全性的需求,与节省可用子网的目标相互冲突.通过使用私有vlan,交换机能够分 ...
- 三维BFS Poj 2251
#include <iostream> #include <cstdio> #include <string> #include <cstring> # ...