[BZOJ4204] 取球游戏(期望)
[题目描述]
有\(m\)个球,一开始每个球均有一个初始标号,标号范围为\(1~n\)且为整数,标号为\(i\)的球有\(a_{i}\)个,并保证\(Σa_{i} = m\)。
每次操作等概率取出一个球(即取出每个球的概率均为\(\frac{1}{m}\)),若这个球标号为\(k(k < n)\),则将它重新标号为\(k + 1\);若这个球标号为\(n\),则将其重标号为\(1\)。(取出球后并不将其丢弃)
现在你需要求出,经过\(K\)次这样的操作后,每个标号的球的期望个数。
\(dp[i]:\)编号为\(i\)的球的个数
\(dp[i]=dp[i]+dp[i−1]∗\frac{1}{m}−dp[i]∗\frac{1}{m}\)
\(dp[i]=\frac{1}{m}dp[i-1]+\frac{m-1}{m}dp[i]\)
写成矩阵形式,发现是个循环矩阵(从第2行开始都是由前一行向右移一位得到的)
循环矩阵乘循环矩阵还是循环矩阵
所以只要记录第一行即可
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int INF=1e9+7;
inline LL read(){
register LL x=0,f=1;register char c=getchar();
while(c<48||c>57){if(c=='-')f=-1;c=getchar();}
while(c>=48&&c<=57)x=(x<<3)+(x<<1)+(c&15),c=getchar();
return f*x;
}
const int MAXN=1005;
int dp[MAXN];
int n,m,k;
struct Matrix{
int N;
double a[MAXN];
friend Matrix operator * (Matrix a,Matrix b){
Matrix res;
res.N=a.N;
/*memset(res.a,0,sizeof res.a);
for(int i=1;i<=a.N;i++)
for(int j=1;j<=b.N;j++)
for(int i=1;i<=a.N;i++)
res.a[i][j]+=a.a[i][k]*b.a[k][j];*/
for(int i=1;i<=res.N;i++){
res.a[i]=0;
for(int j=1;j<=res.N;j++)
res.a[i]+=a.a[j]*b.a[(i-j+res.N)%res.N+1];
}
return res;
}
};
inline Matrix qpow(Matrix a,int b){
Matrix res;
res.N=a.N;
memset(res.a,0,sizeof res.a);
res.a[1]=1;
while(b){
if(b&1) res=res*a;
a=a*a;
b>>=1;
}
return res;
}
int main(){
// freopen("asd.in","r",stdin);
n=read(),m=read(),k=read();
for(int i=1;i<=n;i++) dp[i]=read();
if(n==1){
printf("%d.000\n",dp[1]);
return 0;
}
Matrix t;
t.N=n;
memset(t.a,0,sizeof t.a);
t.a[1]=(double)(m-1)/m;
t.a[2]=(double)1.0/m;
t=qpow(t,k);
assert(t.N==n);
for(int i=1;i<=n;i++){
double ans=0;
for(int j=1;j<=n;j++)
ans+=(double)dp[j]*t.a[(i-j+t.N)%t.N+1];
printf("%.3lf\n",ans);
}
}
[BZOJ4204] 取球游戏(期望)的更多相关文章
- bzoj4204: 取球游戏
好神啊.. 首先递推随便yy一下就行了 然后发现可以用矩阵优化,不过显然是n^3logk的,不资磁 于是就有了性质,这个转移矩阵显然是一个循环矩阵(并不知道) 循环矩阵乘循环矩阵还是循环矩阵 然后就可 ...
- nyist 518 取球游戏
http://acm.nyist.net/JudgeOnline/problem.php?pid=518 取球游戏 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 今 ...
- 取球游戏|2012年蓝桥杯B组题解析第十题-fishers
(25')取球游戏 今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断. 我们约定: 每个人从盒子中取出 ...
- 取球游戏_nyoj_518(博弈-蓝桥杯原题).java
取球游戏 时间限制: 1000 ms | 内存限制: 65535 KB 难度: 2 描述 今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下 ...
- nyoj_518_取球游戏_201404161738
取球游戏 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下多少个 ...
- 蓝桥杯 第三届C/C++预赛真题(10) 取球游戏(博弈)
今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断. 我们约定: 每个人从盒子中取出的球的数目必须是:1 ...
- hihoCoder offer 收割练习赛 74B 取球游戏
Observations 存在取球策略使得每个四连通块可以只剩一个球:保证取走一个球后仍然是个四连通块. 定义新的[相邻]关系:两球在同一行中且所在行中二者之间无其他球,或者两球在同一列且所在列中二者 ...
- java实现取球游戏
/* 今盒子里有 n 个小球,A.B 两人轮流从盒中取球,每个人都可以看到另一个人取了多少个, 也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断. 我们约定: 每个人从盒子中取出的球的 ...
- 2016蓝桥杯"取球博弈"问题
较难,网上有能得出正确结果的代码,但是读了一下,像是拼凑出的结果,逻辑不通,代码和注释不符 参考网上代码写了一版,结构相对清晰,注释比较详细 题目很长: 两个人玩取球的游戏.一共有N个球,每人轮流取球 ...
随机推荐
- linux环境下搭建osm_web服务器一(Postgresql配置及osm2pgsql原始数据导入):
Postgresql配置及osm2pgsql原始数据导入 2012年,Ubuntu 12.04LTS发布,又一个长效支持版,我们又该更新OpenStreetMap服务器了,这次,将详细在博客中记录配置 ...
- turntable
1.业务流程 2.80001代码逻辑 3.80002代码逻辑 4抽奖概率计算
- Matlab中的数据预处理-归一化(mapminmax)与标准化(mapstd)
一.mapminmax 意思是将矩阵的每一行处理成[-1,1]区间,此时对于模式识别或者其他统计学来说,数据应该是每一列是一个样本,每一行是多个样本的同一维,即对于一个M*N的矩阵来说,样本的维度是M ...
- charles4.2下载与破解方法以及配置https.RP
Charles下载地址 地址:https://www.charlesproxy.com/latest-release/download.do 2. Charles破解 破解地址:https://www ...
- java中List的用法和实例详解
java中List的用法和实例详解 List的用法List包括List接口以及List接口的所有实现类.因为List接口实现了Collection接口,所以List接口拥有Collection接口提供 ...
- html传参数 js工具类
var QueryUtils = { GetQueryString: function (name) { var reg = new RegExp("(^|&)" + na ...
- mysql 事物ACID和隔离级别
⑴ 原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,这和前面两篇博客介绍事务的功能是一样的概念,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则 ...
- [GO]用go语言实现区块链工作原理
基本原理这里就不写了,只写一个简单demo的实现 首先得有一个区块用来存储区块头和区块体 type Block struct { Version int64 PreBlockHash []byte H ...
- C#开发重用方法
获取类型先关信息 GetType()及typeof()
- DNS被污染后
如果有条件,自已DNS还是非常必要的,至少有一亩三分地的净土. 但是DNS污染是无处不在的,特别是 Forwarding的记录, 一旦 IPv6 Tunnel连接失败,DNS Server 瞬间就被 ...