洛谷 3706 [SDOI2017]硬币游戏——思路
题目:https://www.luogu.org/problemnew/show/P3706
题解:https://blog.csdn.net/gjghfd/article/details/80355976
令 \( p_x \) 表示哪个串都没在结尾匹配上的概率,那么在 \( p_x \) 的基础上再出现 m 个特定的字符就能拼出任意一个串了。
但是在再出现 m 个字符的过程中可能已经匹配上了某个串,比如 HTT 和 THT ,想在 \( p_x \) 的基础上出现 THT 拼出第二个串,但如果是 \( p_x \) 里长成 HT 样子的串的话,再出现一个 T 就会以第一个串为结尾结束了。
每个字符出现的概率是一样的。所以可以认为 \( p_x \) 里出现形如 HT 或者 ***HT ( ***HT 没有匹配上一个串) 之类的串的概率是 \( ( \frac{1}{2} )^2 \) 。不过不太知道为什么是这样。
所以就有 \( p_x*\frac{1}{2^m} = p_i+\sum\limits_{j=1}^{n}p_j\sum\limits_{l \in L_{i,j}}\frac{1}{2^{m-l}} \) ,其中 \( L_{i,j} \) 表示 i 的前缀与 j 的后缀可以匹配的长度的集合。
还有一个式子就是 \( \sum\limits_{i=1}^{n}p_i = 1 \) ,就能高斯消元了。
可以用哈希求 \( L_{i,j} \) 。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
#define db long double
using namespace std;
const int N=,b1=1e9+,b2=,m1=1e9+,m2=;
int n,m,pw[N][];
bool b[N][N]; db bin[N],a[N][N];
struct Node{
int v0,v1;
Node(int a=,int b=):v0(a),v1(b) {}
bool operator== (const Node &b)const
{return v0==b.v0&&v1==b.v1;}
}h[N][N];
Node get_h(int i,int j)
{
int r0=(h[i][m].v0-(ll)h[i][j-].v0*pw[m-j+][])%m1;
int r1=(h[i][m].v1-(ll)h[i][j-].v1*pw[m-j+][])%m2;
if(r0<)r0+=m1; if(r1<)r1+=m2;
return Node(r0,r1);
}
void solve()
{
pw[][]=pw[][]=;
for(int i=;i<=m;i++)
{
pw[i][]=(ll)pw[i-][]*b1%m1;
pw[i][]=(ll)pw[i-][]*b2%m2;
}
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
{
h[i][j].v0=((ll)h[i][j-].v0*b1+b[i][j])%m1;
h[i][j].v1=((ll)h[i][j-].v1*b2+b[i][j])%m2;
}
for(int i=;i<=n;i++)a[i][]=-bin[m];//a[][0]:px
a[][n+]=;for(int i=;i<=n;i++)a[][i]=;//a[0][]:sum=1
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
for(int k=;k<=m;k++)
if(h[i][k]==get_h(j,m-k+)) a[i][j]+=bin[m-k];
}
void gauss()
{
for(int i=;i<=n;i++)
{
int bh=i;
for(int j=i+;j<=n;j++)
if(fabs(a[j][i])>fabs(a[bh][i]))bh=j;
for(int j=i;j<=n+;j++)swap(a[i][j],a[bh][j]);
db sl=a[i][i];
for(int j=i;j<=n+;j++)a[i][j]/=sl;//
for(int j=;j<=n;j++)
if(j!=i&&fabs(a[j][i]))
{
sl=a[j][i];
for(int k=i;k<=n+;k++)a[j][k]-=sl*a[i][k];
}
}
}
int main()
{
scanf("%d%d",&n,&m); char ch[N];
bin[]=;for(int i=;i<=m;i++)bin[i]=bin[i-]/;
for(int i=;i<=n;i++)
{
scanf("%s",ch+);
for(int j=;j<=m;j++)b[i][j]=(ch[j]=='H');
}
solve(); gauss();
for(int i=;i<=n;i++)
printf("%.10Lf\n",a[i][n+]);
return ;
}
洛谷 3706 [SDOI2017]硬币游戏——思路的更多相关文章
- 洛谷P3706 [SDOI2017]硬币游戏(概率生成函数+高斯消元)
题面 传送门 题解 不知道概率生成函数是什么的可以看看这篇文章,题解也在里面了 //minamoto #include<bits/stdc++.h> #define R register ...
- BZOJ.4820.[SDOI2017]硬币游戏(思路 高斯消元 哈希/AC自动机/KMP)
BZOJ 洛谷 建出AC自动机,每个点向两个儿子连边,可以得到一张有向图.参照 [SDOI2012]走迷宫 可以得到一个\(Tarjan\)+高斯消元的\(O((nm)^3)\)的做法.(理论有\(6 ...
- 洛咕 P3706 [SDOI2017]硬币游戏
假设f[i]是第i个同学胜利的概率,也就是随机序列第一个匹配到s[i]的概率 假设前面有一个字符串\(S\),(假设无限长但没有匹配),现在往后面要加上第i个串\(s[i]\),这个的概率设为\(P_ ...
- 【BZOJ4820】[SDOI2017]硬币游戏(高斯消元)
[BZOJ4820][SDOI2017]硬币游戏(高斯消元) 题面 BZOJ 洛谷 题解 第一眼的感觉就是构\(AC\)自动机之后直接高斯消元算概率,这样子似乎就是\(BZOJ1444\)了.然而点数 ...
- 洛谷P1118 数字三角形游戏
洛谷1118 数字三角形游戏 题目描述 有这么一个游戏: 写出一个1-N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行这样的操作,显然每次构成的序列都比上一次的序列长度少1,直 ...
- BZOJ:4820: [Sdoi2017]硬币游戏&&BZOJ:1444: [Jsoi2009]有趣的游戏(高斯消元求概率)
1444: [Jsoi2009]有趣的游戏 4820: [Sdoi2017]硬币游戏 这两道题都是关于不断随机生成字符后求出现给定字符串的概率的问题. 第一题数据范围较小,将串建成AC自动机以后,以A ...
- [Sdoi2017]硬币游戏 [高斯消元 KMP]
[Sdoi2017]硬币游戏 题意:硬币序列,H T等概率出现,\(n \le 300\)个人猜了一个长为$ m \le 300$的字符串,出现即获胜游戏结束.求每个人获胜概率 考场用了[1444: ...
- 洛谷P1274-魔术数字游戏
Problem 洛谷P1274-魔术数字游戏 Accept: 118 Submit: 243Time Limit: 1000 mSec Memory Limit : 128MB Probl ...
- 4820: [Sdoi2017]硬币游戏
4820: [Sdoi2017]硬币游戏 链接 分析: 期望dp+高斯消元. 首先可以建出AC自动机,Xi表示经过节点i的期望次数,然后高斯消元,这样点的个数太多,复杂度太大.但是AC自动机上末尾节点 ...
随机推荐
- java使用HttpClient
HttpClient常用的包有两个 org.apache.http.client以及org.apache.commons.httpclient 我常用的是org.apache.http.client. ...
- OAF 标准的供应商管理员批准流程
标准供应商审批流程 oracle.apps.pos.onboard.webui.FlexRegApproverPGCO--初始化poplist LinkedList actionListText = ...
- react项目打包后路径找不到,项目打开后页面空白的问题
使用 npm install -g create-react-app快速生成项目脚手架打包后出现资源找不到的路径问题: 解决办法:在package.json设置homepage
- linux下安装nodejs及cnpm
http://www.runoob.com/nodejs/nodejs-install-setup.html https://www.cnblogs.com/zqzjs/archive/2017/01 ...
- hibernate一级缓存和二级缓存的区别
http://blog.csdn.net/defonds/article/details/2308972 缓存是介于应用程序和物理数据源之间,其作用是为了降低应用程序对物理数据源访问的频次,从而提高了 ...
- Activiti进阶(二)——部署流程资源的三种方式
转自:http://blog.csdn.net/zjx86320/article/details/50234707 流程资源可以是各种类型的文件,在启动流程或流程实例运行过程中会被读取.下面介绍常用的 ...
- BZOJ1300 [LLH邀请赛]大数计算器
一开始以为暴力搞,后来看了数据范围还以为要FFT,各种被虐,然后Orz Seter大神!!! 我只想到了前三位:a * b <=> 10^(log(a) + log(b)),于是把乘的数都 ...
- js通过class获取元素
<!doctype html> <html> <head> <meta charset="utf-8"> <meta char ...
- [转载]struts1小项目
http://www.blogjava.net/nokiaguy/archive/2009/01/13/251101.html
- python中read()、readline()、readlnes()
在python中 1.file.read()直接按原样读取文件,它通常用于将文件内容放到一个字符串变量中,如果文件大于可用内存,则不可能实现这种处理,因为原来文件里面是str_class,所以 fil ...