麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

【hdu3689】 Infinite monkey theorem

2019-11-14 09:54:31
字體:
供稿:網(wǎng)友

題意 字符集中有一些字符(最多26個),給出每個字符的出現(xiàn)概率(它們的和保證為1) 再給出一個子串B,長為M 求:任給一個長度為N的字符串A(只能包含字符集中的字符),使得B是A的子串的概率。 N<=100

解法 DP 想象一邊隨機(jī)生成字符串A,一邊用KMP匹配字符串B的過程 f[i][j]表示隨機(jī)生成到第i位,此時B串匹配到第j位的概率 枚舉下一位生成字符c,設(shè)其生成概率為gc 假設(shè)下一位填c,計算出KMP匹配指針j應(yīng)該移動到j(luò)‘ f[i+1][j’] += f[i][j]*gc 已經(jīng)匹配到第m位的狀態(tài)不再進(jìn)行轉(zhuǎn)移 ans = ∑f[i][m]

一道比較簡單的概率DP結(jié)合了KMP非常的巧妙。

#include<iostream>#include<cstdio>#include<cstring>#include<string>#include<algorithm>using namespace std;double f[1010][30],ll,gl[30];int nxt[30],n,m,l;char w[30],ch,c[30];void calc_w(){ nxt[1]=0; l=strlen(w+1); int j=0; for (int i=2;i<=l;i++) { while (j&&w[i]!=w[j+1])j=nxt[j]; if (w[j+1]==w[i])j++; nxt[i]=j; }}int main(){ while(1) { memset(f,0,sizeof(f)); f[0][0]=1; scanf("%d%d/n",&n,&m); if (!n&&!m)break; for (int i=1;i<=n;i++) scanf("%c %lf/n",&c[i],&gl[i]); scanf("%s",w+1); calc_w(); for (int i=0;i<m;i++) { for (int j=0;j<l;j++) { for (int k=1;k<=n;k++) { int po=j; while (po&&w[po+1]!=c[k])po=nxt[po]; if (w[po+1]==c[k])po++; f[i+1][po]+=f[i][j]*gl[k]; } } } double ans=0; for (int i=0;i<=m;i++) ans+=f[i][l];
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 婷婷中文字幕一区二区三区 | 日韩黄色一区 | 欧美a黄 | 369看片你懂的小视频在线观看 | 久久精品视频日本 | 欧美城网站地址 | 国产亚洲自拍一区 | 久草成人在线观看 | 亚洲影视在线 | 高清国产在线 | 高清成人在线 | 欧美一级网 | 亚洲av一级毛片特黄大片 | 一级电影在线观看 | 日韩视频一| 黄色特级一级片 | 99欧美精品 | 久久久日韩精品一区二区 | 国产亚洲精品综合一区91 | chinese hd xxxx tube| 久久美女色视频 | 国产精品成人一区二区三区电影毛片 | 日韩黄色av网站 | 色人阁导航 | 成人免费一区 | 久久精品9 | 日韩激情在线视频 | 亚洲一级网站 | 亚洲精品v天堂中文字幕 | 欧美一级毛片特黄黄 | 欧美亚洲综合网 | 2017亚洲男人天堂 | 98色视频| 久久久久久久久久亚洲精品 | 一级黄色毛片播放 | 午夜视频亚洲 | 欧美a黄 | 国产精品v片在线观看不卡 成人一区二区三区在线 | 欧美在线黄色 | 欧美熟videos肥婆 | 免费国产一级淫片 |