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 ...
随机推荐
- yolo原理学习
1.[yolov1] 第一步:将图像划分为S*S的栅格(grid cell),这里分成了7*7的grid cell.栅格的任务是:检测中心落在该栅格中的物体(注意,栅格中心未必与物体的中心重合, ...
- 【原】RHEL6.0企业版安装
作者:david_zhang@sh [转载时请以超链接形式标明文章] 链接:http://www.cnblogs.com/david-zhang-index/p/4166846.html 本文适用RH ...
- Deques and Randomized Queues
1. 题目重述 完成三个程序,分别是双向队列,随机队列,和随机队列读取文本并输出k个数. 2. 分析 2.1 双向队列 题目的性能要求是,操作时间O(1),内存占用最大48n+192byte. 当使用 ...
- 【eclipse插件开发实战】Eclipse插件开发2——SWT
Eclipse插件开发实战2--SWT 一.SWT简介 SWT(StandardWidget Toolkit) 标准小窗口工具箱,一开源的GUI编程框架,与AWT/Swing有相似的用处,eclips ...
- Flutter实战视频-移动电商-40.路由_Fluro的全局注入和使用方法
40.路由_Fluro的全局注入和使用方法 路由注册到顶层,使每个页面都可以使用,注册到顶层就需要在main.dart中 main.dart注册路由 注入 onGenerateRoute是Materi ...
- ThinkPHP3.2.3中,配置文件里配置项的读取
在ThinkPHP3.2.3的版本中,配置项的读取,有两种情况. 是在PHP文件或者在PHP代码中的读取方法为C函数,例如:C('配置项的名称'); 在HTML模板中的读取方法为,例如{$Think. ...
- 计算机图形学DDA画线法+中点画线法+Bresenham画线法
#include <cstdio> #include <cstring> #include <conio.h> #include <graphics.h> ...
- hoj2662 Pieces Assignment
Pieces Assignment My Tags (Edit) Source : zhouguyue Time limit : 1 sec Memory limit : 64 M S ...
- 【OpenJ_Bailian - 3468】电池的寿命(贪心)
电池的寿命 Descriptions: 小S新买了一个掌上游戏机,这个游戏机由两节5号电池供电.为了保证能够长时间玩游戏,他买了很多5号电池,这些电池的生产商不同,质量也有差异,因而使用寿命也有所不同 ...
- spring框架——依赖注入
依赖注入:DI 又称控制反转:IoC 项目名字spring_DI 一.implement包中定义了两个接口Food和Person 1.接口Food package org.interfaces; pu ...