传送门:http://uoj.ac/problem/299

题目良心给了Bayes定理,但对于我这种数学渣来说并没有什么用。

先大概讲下相关数学内容:

1.定义:$P(X)$ 表示事件$X$发生的概率,$E(X)$表示随机变量$X$的期望值,$P(A|B)$表示已知$B$发生,$A$发生的概率,$P(AB)$表示$A$和$B$同时发生的概率。

2.条件概率公式:

$\begin{aligned}P(A|B)=\frac{P(AB)}{P(B)}\end{aligned}$。

由$P(B)P(A|B)=P(AB)$移项可得。

3.全概率公式:

当存在$k$个互斥事件且事件并集为全集时:

$P(A)=\sum\limits_{i=1}^{k}P(A|X=X_i)P(X=Xi)$

由条件概率公式可得。

4.Bayes定理:

$\begin{aligned}P(A|B)=\frac{P(AB)}{P(B)}=\frac{P(B|A)P(A)}{P(B)}\end{aligned}$

由条件概率公式可得。

接下来是OI部分。

对于每个位置,找到夹着它的两个已知胜负条件,设为A和B。

将A作为必要条件(题设),可知$E(C)=\sum_{i=1}^{k}P(c_i=1)$。根据Bayes公式可得$\begin{aligned}P(c_i=1|B)=\frac{P(c_i=1)P(B|c_i=1)}{P(B)}=\frac{P(c_i=1,B)}{P(B)}\end{aligned}$

修改的时候使用线段树进行区间合并,用矩阵加速合并。

设节点$x$代表的区间是$[L,R]$,则val[x][0/1][0/1]表示$L-1$为胜/负时,R为胜/负的$P(c_L=1)*P(B|c_L=1)$和$P(B)$。

接下来是暴力部分(10分)。

指数级枚举所有状态,计算这个状态出现的概率以及是否合法,累加即可。

方法一:暴力

 #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; const int N=;
char S[];
int n,m;
double p[N],q[N],w[]; void calc(){
double ans=,tp=;
int up=(<<n);
for(int i=;i<up;i++){
bool f=; int c=,las=; double pc=;
for(int j=,k=;j<n;j++,k++)
if(i&(<<j)){
if(w[k]==){ f=false; break; }
c++;
if (las) pc*=p[k]; else pc*=q[k];
las=;
}else{
if(w[k]==){ f=false; break; }
if(las)pc*=(-p[k]); else pc*=(-q[k]);
las=;
}
if(f)ans+=pc*c,tp+=pc;
}
ans/=tp; printf("%.6f\n",ans);
} void solve(){
for(int i=;i<=n;i++)w[i]=-;
for(int i=,x,y;i<=m;i++){
scanf("%s",S);
if(S[]=='a') scanf("%d%d",&x,&y),w[x]=y; else scanf("%d",&x),w[x]=-;
calc();
}
} int main(){
freopen("game.in","r",stdin);
freopen("game.out","w",stdout);
scanf("%d%d",&n,&m); scanf("%s",S);
scanf("%lf",&p[]);
for(int i=;i<=n;i++)scanf("%lf %lf",&p[i],&q[i]);
solve();
return ;
}

方法二:正解

 #include<set>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ls (x<<1)
#define rs (ls|1)
#define rep(i,l,r) for (int i=(l); i<=(r); i++)
using namespace std; const int N=;
int n,m,p,c,type,S2[N];
double ans,P[N],Q[N];
set<int>S1;
char op[]; struct M{ double v[][]; M(){ memset(v,,sizeof(v)); }; };
M operator +(M a,const M &b){ rep(i,,) rep(j,,) a.v[i][j]+=b.v[i][j]; return a; }
M operator *(const M &a,const M &b){ M c; rep(i,,) rep(j,,) rep(k,,) c.v[i][j]+=a.v[i][k]*b.v[k][j]; return c; } struct inf{ M f,g; inf(const M &_f=M(),const M &_g=M()):f(_f),g(_g){}; };
inf operator +(const inf &a,const inf &b){ return inf(a.f*b.f,a.g*b.f+a.f*b.g); }
struct node{ int l,r,mid; inf val; }seg[N<<]; void build(int x,int l,int r){
if (l==r){
seg[x].val.f.v[][]=P[l]; seg[x].val.f.v[][]=.-P[l];
seg[x].val.f.v[][]=Q[l]; seg[x].val.f.v[][]=.-Q[l];
seg[x].val.g.v[][]=P[l]; seg[x].val.g.v[][]=Q[l];
return;
}
int mid=(l+r)>>;
build(ls,l,mid); build(rs,mid+,r); seg[x].val=seg[ls].val+seg[rs].val;
} inf que(int x,int L,int R,int l,int r){
if (L==l && r==R) return seg[x].val;
int mid=(L+R)>>;
if (r<=mid) return que(ls,L,mid,l,r);
else if (l>mid) return que(rs,mid+,R,l,r);
else return que(ls,L,mid,l,mid)+que(rs,mid+,R,mid+,r);
} double ask(int l,int r){ inf v=que(,,n+,l+,r); return v.g.v[S2[l]][S2[r]]/v.f.v[S2[l]][S2[r]]; } int main(){
freopen("game.in","r",stdin);
freopen("game.out","w",stdout);
scanf("%d%d",&n,&m); scanf("%s",op); scanf("%lf",&P[]);
rep(i,,n) scanf("%lf%lf",&P[i],&Q[i]);
S1.insert(); S2[]=; S1.insert(n+); S2[n+]=; P[n+]=Q[n+]=.;
build(,,n+); ans=ask(,n+);
while (m--){
scanf("%s",op);
if (*op=='a'){
scanf("%d%d",&p,&c); set<int>::iterator nxt=S1.lower_bound(p),lst=nxt; lst--;
S2[p]=c; ans-=ask(*lst,*nxt); ans+=ask(*lst,p)+ask(p,*nxt); S1.insert(p);
}else{
scanf("%d",&p); set<int>::iterator mid=S1.find(p),lst,nxt;
lst=nxt=mid; lst--; nxt++; ans-=ask(*lst,p)+ask(p,*nxt); ans+=ask(*lst,*nxt); S1.erase(p);
}
printf("%.6lf\n",ans);
}
return ;
}

[CTSC2017]游戏(Bayes定理,线段树)的更多相关文章

  1. 【BZOJ-2892&1171】强袭作战&大sz的游戏 权值线段树+单调队列+标记永久化+DP

    2892: 强袭作战 Time Limit: 50 Sec  Memory Limit: 512 MBSubmit: 45  Solved: 30[Submit][Status][Discuss] D ...

  2. 【题解】 AtCoder ARC 076 F - Exhausted? (霍尔定理+线段树)

    题面 题目大意: 给你\(m\)张椅子,排成一行,告诉你\(n\)个人,每个人可以坐的座位为\([1,l]\bigcup[r,m]\),为了让所有人坐下,问至少还要加多少张椅子. Solution: ...

  3. BZOJ.3693.圆桌会议(Hall定理 线段树)

    题目链接 先考虑链.题目相当于求是否存在完备匹配.那么由Hall定理,对于任意一个区间[L,R],都要满足[li,ri]完全在[L,R]中的ai之和sum小于等于总位置数,即R-L+1.(其实用不到H ...

  4. LOJ.6062.[2017山东一轮集训]Pair(Hall定理 线段树)

    题目链接 首先Bi之间的大小关系没用,先对它排序,假设从小到大排 那么每个Ai所能匹配的Bi就是一个B[]的后缀 把一个B[]后缀的匹配看做一条边的覆盖,设Xi为Bi被覆盖的次数 容易想到 对于每个i ...

  5. loj#6062. 「2017 山东一轮集训 Day2」Pair hall定理+线段树

    题意:给出一个长度为 n的数列 a和一个长度为 m 的数列 b,求 a有多少个长度为 m的连续子数列能与 b匹配.两个数列可以匹配,当且仅当存在一种方案,使两个数列中的数可以两两配对,两个数可以配对当 ...

  6. [BZOJ3693]圆桌会议[霍尔定理+线段树]

    题意 题目链接 分析 又是一个二分图匹配的问题,考虑霍尔定理. 根据套路我们知道只需要检查 "区间的并是一段连续的区间" 这些子集. 首先将环倍长.考虑枚举答案的区间并的右端点 \ ...

  7. [BZOJ2138]stone[霍尔定理+线段树]

    题意 一共有 \(n\) 堆石子,每堆石子有一个数量 \(a\) ,你要进行 \(m\) 次操作,每次操作你可以在满足前 \(i-1\) 次操作的回答的基础上选择在 \([L_i,R_i]\) 区间中 ...

  8. BZOJ3693: 圆桌会议(Hall定理 线段树)

    题意 题目链接 Sol 好的又是神仙题... 我的思路:对于区间分两种情况讨论,一种是完全包含,另一种是部分包含.第一种情况非常好判断,至于计算对于一个区间[l, r]的$\sum a[i]$就可以了 ...

  9. 模拟赛 怨灵退治 题解(Hall定理+线段树)

    题意: 有 n 群怨灵排成一排,燐每秒钟会选择一段区间,消灭至多 k 只怨灵. 如果怨灵数量不足 k,则会消灭尽量多的怨灵. 燐作为一只有特点的猫,它选择的区间是不会相互包含的.它想要知道它每秒最多能 ...

随机推荐

  1. [学习笔记]可持久化数据结构——数组、并查集、平衡树、Trie树

    可持久化:支持查询历史版本和在历史版本上修改 可持久化数组 主席树做即可. [模板]可持久化数组(可持久化线段树/平衡树) 可持久化并查集 可持久化并查集 主席树做即可. 要按秩合并.(路径压缩每次建 ...

  2. CSS3不遥远,几个特性你要知道

    CSS是众所周知且应用广泛的网站样式语言,在它的版本三(CSS3)计划中,新增了一些能够节省时间的特性.尽管只有当前最新了浏览器版本才能支持这些 效果,但了解它们还是必须且很有趣味性的.CSS3中的5 ...

  3. 运用yunwei.zip压缩包安装过程:

    12   yum install lrzsz -y     13  rz    14  ll    15  unzip -o yunwei.zip     16  unzip yunwei.zip  ...

  4. Idea切换svn分支,类似Eclipse的Switch功能

    vcs --> subversion --> update directory --> 勾选中 Update/Switch to specific url 重新设置新的URL即可

  5. IDEA无法编译java8的lambda表达式提示Error:(16, 48) java: -source 1.5 中不支持 lambda 表达式

    在idea中新建了一个java8的项目,但是写lambda表达式提示语法错误,提示如下错误信息: Error:(16, 48) java: -source 1.5 中不支持 lambda 表达式 (请 ...

  6. POJ 1062 昂贵的聘礼 (最短路 迪杰斯特拉 )

    题目链接 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请 ...

  7. mobius反演讲解

    mobius反演的基本形式为,假设知道函数F(x)=Σf(d) d|x,那么我们可以推出f(x)=Σmiu(d)*F(x/d) d|x,另一基本形式为假设知道函数F(x)=Σf(d) x|d,那么我们 ...

  8. Pycharm中快捷键大全

    #1.按住ctrl然后鼠标放在函数上就会提示出这个函数有那些参数,双击进入该函数. 1.Pycharm中快捷键大全,遇到一个更新一个 撤销与反撤销:Ctrl + z,Ctrl + Shift + z ...

  9. requests上传文件

    """ requests上传文件时,如果文件名是中文,会导致上传失败,参考:https://www.cnblogs.com/liaofeifight/p/5807901. ...

  10. wxpython布局管理部件wx.gridbagsizer用法示例

    text = ("This is text box")         panel = wx.Panel(self, -1)         chkAll1 = wx.CheckB ...