题链:

http://acm.hdu.edu.cn/showproblem.php?pid=3689
题解:

KMP,概率dp
(字符串都从1位置开始)
首先对模式串S建立next数组。
定义dp[i][j]表示猴子打的串长度为i,且该串的后缀与模式串最多匹配到j位置的概率。
显然dp[0][0]=1,
考虑如何转移:
枚举下一个打出的字符为c,然后用kmp的next数组找到模式串中可以继续匹配的位置k。
即:k=j+1; while(k&&S[k]!=c) k=next[k];
然后将dp[i][j]贡献给dp[i+1][k],由全概率公式可得到的:
"猴子打了i个字符,最多匹配到模式串的第j个字符"这个事件为前提条件时,
有p(c)的概率发生"猴子打了i+1个字符,最多匹配到了模式串的第k个字符"这个事件。
所以dp[i+1][k]+=dp[i][j]*p(c)

代码:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. char key[30];
  4. double p[30],dp[1005][15],ans;
  5. int nxt[15];
  6. int C,N;
  7. void buildnxt(char *S){
  8. int n=strlen(S+1),j,k;
  9. nxt[1]=0; j=1; k=0;
  10. while(j<=n){
  11. if(k==0||S[j]==S[k]){
  12. j++; k++; nxt[j]=k;
  13. }
  14. else k=nxt[k];
  15. }
  16. }
  17. int main(){
  18. static char S[15];
  19. while(1){
  20. scanf("%d%d",&C,&N);
  21. if(!C&&!N) break;
  22. for(int i=1;i<=C;i++)
  23. scanf(" %c%lf",&key[i],&p[i]);
  24. scanf("%s",S+1);
  25. int len=strlen(S+1);
  26. buildnxt(S);
  27. for(int i=0;i<=N;i++)
  28. for(int j=0;j<=len;j++) dp[i][j]=0;
  29. dp[0][0]=1;
  30. for(int i=0;i<N;i++)
  31. for(int j=0;j<len;j++){
  32. if(dp[i][j]==0) continue;
  33. for(int c=1;c<=C;c++){
  34. int k=j+1;
  35. while(k&&S[k]!=key[c]) k=nxt[k];
  36. dp[i+1][k]+=dp[i][j]*p[c];
  37. }
  38. }
  39. ans=0;
  40. for(int i=1;i<=N;i++) ans+=dp[i][len];
  41. printf("%.2lf%%\n",ans*100);
  42. }
  43. return 0;
  44. }

  

●HDU 3689 Infinite monkey theorem的更多相关文章

  1. hdu 3689 Infinite monkey theorem

    Infinite monkey theorem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/ ...

  2. HDU 3689 Infinite monkey theorem [KMP DP]

    Infinite monkey theorem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...

  3. HDU 3689 Infinite monkey theorem(DP+trie+自动机)(2010 Asia Hangzhou Regional Contest)

    Description Could you imaging a monkey writing computer programs? Surely monkeys are smart among ani ...

  4. [HDU 3689]Infinite monkey theorem (KMP+概率DP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3689 黄老师说得对,题目只有做wa了才会有收获,才会有提高. 题意:一个猴子敲键盘,键盘上有n个键,猴 ...

  5. [AC自己主动机+可能性dp] hdu 3689 Infinite monkey theorem

    意甲冠军: 给n快报,和m频率. 然后进入n字母出现的概率 然后给目标字符串str 然后问m概率倍的目标字符串是敲数量. 思维: AC自己主动机+可能性dp简单的问题. 首先建立trie图,然后就是状 ...

  6. HDU 3689 Infinite monkey theorem ——(自动机+DP)

    这题由于是一个单词,其实直接kmp+dp也无妨.建立自动机当然也是可以的.设dp[i][j]表示匹配到第i个字母的时候,在单词中处于第j个位置的概率,因此最终的答案是dp[0~m][len],m是输入 ...

  7. hdu 3689 杭州 10 现场 J - Infinite monkey theorem 概率dp kmp 难度:1

    J - Infinite monkey theorem Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d &am ...

  8. HUD3689 Infinite monkey theorem

    Infinite monkey theorem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/ ...

  9. Infinite monkey theorem(hdu 3689)

    题意:问随机生成一个长度为m(m<=1000)长度的字符串,出现某个子串s的概率是多少. /* KMP+DP 设f[i][j]表示A生成到第i位,此时B串匹配到第j位的概率. 转移方程为f[i+ ...

随机推荐

  1. 201621123050 《Java程序设计》第11周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线程 1. 源代码阅读:多线程程序BounceThread 1.1 BallR ...

  2. Beta冲刺Day5

    项目进展 李明皇 今天解决的进度 服务器端还未完善,所以无法进行联动调试.对页面样式和逻辑进行优化 明天安排 前后端联动调试 林翔 今天解决的进度 完成维护登录态,实现图片上传,微信开发工具上传图片不 ...

  3. ASCII排序

    ASCII码排序 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符.   输入 第一行输 ...

  4. STL之queue

    描述 使用STL中的queue,完成入队.出队.获取队首.获取队尾等基本操作. 部分代码已经给出,请补充完整,提交时请勿包含已经给出的代码. int main() { queue<int> ...

  5. JAVA_SE基础——45.基本类型变量.值交换[独家深入解析]

    需求:定义一个函数交换两个基本类型变量的值. 相信看过我前面的文章的同学都应该看的懂我以下的代码: class Demo2 { public static void main(String[] arg ...

  6. JAVA_SE基础——3.Java程序的开发流程

    上一篇,写的是JAVA的环境变量的配置,今天我抽空写篇Java程序的开发流程,下面的教程是我结合书本和毕向东老师的视频写下的心的~ 在没有真正写Java程序前,首先需要了解Java程序的开发过程. S ...

  7. redis命令详解

      redis中添加key value元素:set key value;       获取元素:get key ;   redis中添加集合:lpush key value1 value2 value ...

  8. PL/SQL Developer 导入导出操作

    一.PL/SQL Developer数据导入 Tools->Import Tables

  9. windbg分析Kernel32.dll导出表

    写在前面的话: 继续上篇,在获得了Kernel32.dll基址的基础上,分析它的导出表结构: 对PE结构不太熟悉的同学,可以参考看雪论坛里的一篇帖子:https://bbs.pediy.com/thr ...

  10. Python系列之 - 面向对象(1)

    python是一门面向对象的编程语言,python中的一切均是对象. 有对象就提到类,对象和类就像是儿子和老子的关系,是不可分的一对. 什么是类     类就是具有一些共同特性的事物的统称.好比人类, ...