题目链接

题目大意:$n$个点, 每个点$i$有成功率$p_i$, 若成功走到$i+1$, 否则走到走到$i-1$, 多组询问, 求从$l$出发, 在$l$处不失败, 最后在$r$处胜利的概率

设$L[l,r]$表示从$l$出发, 在$l$处不失败, 最后在$r$处胜利的概率,$R[l,r]$表示从$r$出发, 在$l$处不失败, 最后在$r$处胜利的概率

记$l_1=L[l,mid],r_1=L[mid+1,r],l_2=R[l,mid],r_2=R[mid+1,r].$

枚举在$mid$到$mid+1$之间往返的次数, 可以得到下式

$$L[l,r]=l_1l_2\sum\limits_{n=0}^\infty{(1-l_2)^nr_1^n}=\frac{l_1l_2}{1-(1-l_2)r_1}$$

$$R[l,r]=r_2+(1-r_2)r_1l_2\sum\limits_{n=0}^\infty{(1-l_2)^nr_1^n}$$

$$=r_2+(1-r_2)\frac{r_1l_2}{1-(1-l_2)r_1}$$

直接用线段树维护就好了

还有另外一种做法, 考虑询问$[l,r]$

设$f_i$表示从$i$走到$r$且在$r$处胜利的概率, 则答案即为$f_l$

规定$f_{l-1}=0,f_{r+1}=1$ 就有$f_i=(1-p_i)f_{i-1}+p_if_{i+1}$

即$f_i-f_{i-1}=p_i(f_{i+1}-f_{i-1})$

令$g_i=f_i-f_{i-1}$ 则有$g_i=p_i(g_{i+1}-g_{i})$

记$a_i=\frac{1}{p_i}-1,$ 可以得到$g_{i+1}=a_ig_i$

由于$\sum_{i=l}^{r+1}{g_i}=1$

所以就可以得到$f_l=g_l=\frac{1}{1+a_l+a_la_{l+1}+...+a_la_{l+1}\cdot \cdot \cdot a_{r}}$

记$A[l,r]=\prod_{i=l}^{r}{a_i}, B[l,r]=\sum_{i=l}^{r}{A_i}$

有$$A[l,r]=A[l,mid]A[mid+1,r]$$

$$B[l,r]=B[l,mid]+A[l,mid]B[mid+1,r]$$

线段树维护$A,B$即可

第一种代码

#include <iostream>
#include <algorithm>
#include <math.h>
#include <cstdio>
#define REP(i,a,n) for(int i=a;i<=n;++i)
#define mid ((l+r)>>1)
#define lc (o<<1)
#define rc (lc|1)
#define ls lc,l,mid
#define rs rc,mid+1,r
using namespace std; const int N = 1e5+;
int n, m;
struct _ {
double L, R;
_ () {}
_ (int x, int y) {L=R=(double)x/y;}
_ (double l,double r) :L(l),R(r) {}
_ operator + (const _ &rhs) const {
return _(L*rhs.L/(-(-rhs.L)*R),rhs.R+(-rhs.R)*R*rhs.L/(-(-rhs.L)*R));
}
} v[N<<]; void build(int o, int l, int r) {
if (l==r) {
int x, y;
scanf("%d%d", &x, &y);
v[o]=_(x,y);
return;
}
build(ls),build(rs),v[o]=v[lc]+v[rc];
} void upd(int o, int l, int r, int pos, int x, int y) {
if (l==r) return v[o]=_(x,y),void();
if (mid>=pos) upd(ls,pos,x,y);
else upd(rs,pos,x,y);
v[o]=v[lc]+v[rc];
} _ qry(int o, int l, int r, int ql, int qr) {
if (ql<=l&&r<=qr) return v[o];
if (mid<ql) return qry(rs,ql,qr);
if (mid>=qr) return qry(ls,ql,qr);
return qry(ls,ql,qr)+qry(rs,ql,qr);
} int main() {
scanf("%d%d", &n, &m);
build(,,n);
REP(i,,m) {
int op, pos, a, b;
scanf("%d", &op);
if (op==) {
scanf("%d%d%d", &pos, &a, &b);
upd(,,n,pos,a,b);
} else {
scanf("%d%d", &a, &b);
printf("%.12lf\n", qry(,,n,a,b).L);
}
}
}

第二种完全类似, 改下公式就行了

#include <iostream>
#include <algorithm>
#include <math.h>
#include <cstdio>
#define REP(i,a,n) for(int i=a;i<=n;++i)
#define mid ((l+r)>>1)
#define lc (o<<1)
#define rc (lc|1)
#define ls lc,l,mid
#define rs rc,mid+1,r
using namespace std; const int N = 1e5+;
int n, m;
struct _ {
double A, B;
_ () {}
_ (int x, int y) {A=B=(double)y/x-;}
_ (double a,double b) :A(a),B(b) {}
_ operator + (const _ &rhs) const {
return _(A*rhs.A,B+A*rhs.B);
}
} v[N<<]; void build(int o, int l, int r) {
if (l==r) {
int x, y;
scanf("%d%d", &x, &y);
v[o]=_(x,y);
return;
}
build(ls),build(rs),v[o]=v[lc]+v[rc];
} void upd(int o, int l, int r, int pos, int x, int y) {
if (l==r) return v[o]=_(x,y),void();
if (mid>=pos) upd(ls,pos,x,y);
else upd(rs,pos,x,y);
v[o]=v[lc]+v[rc];
} _ qry(int o, int l, int r, int ql, int qr) {
if (ql<=l&&r<=qr) return v[o];
if (mid<ql) return qry(rs,ql,qr);
if (mid>=qr) return qry(ls,ql,qr);
return qry(ls,ql,qr)+qry(rs,ql,qr);
} int main() {
scanf("%d%d", &n, &m);
build(,,n);
REP(i,,m) {
int op, pos, a, b;
scanf("%d", &op);
if (op==) {
scanf("%d%d%d", &pos, &a, &b);
upd(,,n,pos,a,b);
} else {
scanf("%d%d", &a, &b);
printf("%.12lf\n", /(+qry(,,n,a,b).B));
}
}
}

Memory and Casinos CodeForces - 712E (概率,线段树)的更多相关文章

  1. Codeforces 787D. Legacy 线段树建模+最短路

    D. Legacy time limit per test:2 seconds memory limit per test:256 megabytes input:standard input out ...

  2. CodeForces 91B Queue (线段树,区间最值)

    http://codeforces.com/problemset/problem/91/B B. Queue time limit per test: 2 seconds memory limit p ...

  3. Vasya and a Tree CodeForces - 1076E(线段树+dfs)

    I - Vasya and a Tree CodeForces - 1076E 其实参考完别人的思路,写完程序交上去,还是没理解啥意思..昨晚再仔细想了想.终于弄明白了(有可能不对 题意是有一棵树n个 ...

  4. loj2537 「PKUWC2018」Minimax 【概率 + 线段树合并】

    题目链接 loj2537 题解 观察题目的式子似乎没有什么意义,我们考虑计算出每一种权值的概率 先离散化一下权值 显然可以设一个\(dp\),设\(f[i][j]\)表示\(i\)节点权值为\(j\) ...

  5. CodeForces 19D Points (线段树+set)

    D. Points time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...

  6. Codeforces 240F. TorCoder 线段树

    线段树统计和维护某一区间内的字母个数.. . . F. TorCoder time limit per test 3 seconds memory limit per test 256 megabyt ...

  7. Almost Regular Bracket Sequence CodeForces - 1095E (线段树,单点更新,区间查询维护括号序列)

    Almost Regular Bracket Sequence CodeForces - 1095E You are given a bracket sequence ss consisting of ...

  8. Sereja and Brackets CodeForces - 380C (线段树+分治思路)

    Sereja and Brackets 题目链接: CodeForces - 380C Sereja has a bracket sequence s1, s2, ..., *s**n, or, in ...

  9. Glass Carving CodeForces - 527C (线段树)

    C. Glass Carving time limit per test2 seconds memory limit per test256 megabytes inputstandard input ...

随机推荐

  1. python类方法、静态方法、实例方法例子

    类方法,静态方法,普通方法 #coding=utf-8   class Foo:     def __init__(self,name):         self.name=name       d ...

  2. 微信公众号为什么要加粉?流量,广告,KPI,吸粉,增粉

    微信公众号为什么要加粉?流量,广告,KPI,吸粉,增粉 1.曾有人这样比喻:当你的粉丝超过100人时,你就像是一本内刊:超过1000人,你就像个布告栏:超过1万人,你就好比一本杂志:超过10万人,你就 ...

  3. Django框架----视图函数补充

    视图函数的补充 1.视图函数:一定是要包含两个对象的(render源码里面有HttpResponse对象)   request对象:----->所有的请求信息   HttpResponse:-- ...

  4. mysql数据库----索引原理与慢查询优化

    一.介绍 1.什么是索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语 ...

  5. MySQL数据库总结

    引擎 查看MySQL默认引擎:show variables like '%storage_engine%'; 查看表引擎:show table status from 数据库名; 修改表引擎alter ...

  6. C++提供了四个转换运算符

    const_cast <new_type> (expression) static_cast <new_type> (expression) reinterpret_cast ...

  7. 20165310 java_blog_week4

    2165310 <Java程序设计>第4周学习总结 教材学习内容总结 继承(extends) 同一个包内:继承除了private修饰的变量与方法 不同包内:不继承private和友好,继承 ...

  8. sql注入学习心得与sqlmap使用心得

    做题是最好的老师 首先先来分享一下我用来练手的题目,实验吧中的简单的sql注入1,2,3 不得不说,sql注入真是一个神奇的东西,至少我以前看起来一点头绪都没有的题目能入手了 首先是简单的sql注入3 ...

  9. PN结讲解

    可能大家在使用半导体器件的时候只是在使用它的电气属性,并没有很好的关心下它是什么原因才有了这样的电气属性,那么我们本篇就从物理结构分析下PN结吧. 首先看一张比较陈旧的图图: (就按自己的笔记简单谈谈 ...

  10. Linux中设备号及设备文件【转】

    本文转载自:http://blog.csdn.net/ymangu666/article/details/39292651 主.次设备号 应用程序可以通过对/dev 目录下的设备文件读写,从而访问实际 ...