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 ...
随机推荐
- PHP开发api接口 -- 安全验证 生成签名
转载博客 ————. http://blog.csdn.net/li741350149/article/details/62887524 REST模式中HTTP请求方法(GET,POST,PUT,DE ...
- 【转载】“error LNK1169: 找到一个或多个多重定义的符号”的解决方法
c++的小细节的地方 原文地址:https://blog.csdn.net/xiaosu123/article/details/5665729 问题描述如下: 有 三个源文件,A.h.B.cpp.C. ...
- c++中的友元重载
1 语法 返回值类型 operator 运算符名称(形参列表) { 重载实体 } --------->operator和运算符名称在一起构造成新的函数名 2 案例 #include <io ...
- 【网络爬虫】【python】网络爬虫(四):scrapy爬虫框架(架构、win/linux安装、文件结构)
scrapy框架的学习,目前个人觉得比较详尽的资料主要有两个: 1.官方教程文档.scrapy的github wiki: 2.一个很好的scrapy中文文档:http://scrapy-chs.rea ...
- CodeForces 748C Santa Claus and Robot (思维)
题意:给定一个机器人的行走路线,求最少的点能使得机器人可以走这样的路线. 析:每次行走,记录一个方向向量,每次只有是相反方向时,才会增加一个点,最后再加上最后一个点即可. 代码如下: #pragma ...
- HDU - 1016 Prime Ring Problem 经典素数环
Prime Ring Problem A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ..., ...
- GcSpreadSheet自定义Tab键选择
最开始的时候需要在GcSpreadSheet中按Tab在需要输入的cell中切换,在模板中定义Tab的切换规则:后来又有一个新的要求,因为在使用的时候会出现数据不平的情况,这个时候需要在标记中的不平数 ...
- html页面选择图片上传时实现图片预览功能
实现效果如下图所示 只需要将下面的html部分的代码放入你的代码即可 (注意引入jQuery文件和html头部的css样式,使用的是ajax提交) <!-- 需引入jQuery 引入样式文件 引 ...
- bzoj 4032: [HEOI2015]最短不公共子串【dp+SAM】
第一.二问: 就是最小的最长公共长度+1,设f[i][j]为a匹配到i,b匹配到j,第一问的转移是f[i][j]=(a[i]==b[j]?f[i-1][j-1]+1:0),第二问的转移是f[i][j] ...
- jzoj5990. 【北大2019冬令营模拟2019.1.6】Bear (状压dp)
题面 题解 我永远讨厌dp.jpg 搞了一个下午优化复杂度最后发现只要有一个小trick就可以A了→_→.全场都插头dp就我一个状压跑得贼慢-- 不难发现我们可以状压,对于每一行,用状态\(S\)表示 ...