zoukankan      html  css  js  c++  java
  • 【BZOJ】2553: [BeiJing2011]禁忌 AC自动机+期望+矩阵快速幂

    【题意】给定n个禁忌字符串和字符集大小alphabet,保证所有字符在集合内。一个字符串的禁忌伤害定义为分割能匹配到最多的禁忌字符串数量(一个可以匹配多次),求由字符集构成的长度为Len的字符串的期望禁忌伤害。n<=5,1<=alphabet<=26,len<=10^9。

    【算法】AC自动机+期望+矩阵快速幂

    【题解】参考:BZOJ2553: [BeiJing2011]禁忌

    首先对于一个确定的字符串,每个匹配的禁忌字符串视为一条线段,就是经典的不重叠最大线段数问题。

    通用的贪心做法:按右端点排序,然后贪心能选就选。

    对禁忌字符串建AC自动机,匹配到关键节点ans++并返回根重新匹配,这正好对应贪心过程(关键节点即字符串结尾,需要传递到所有以它为fail的节点)

    设f[i][j]表示串长 i 匹配到节点 j 的期望,根据全期望公式:(期望只能倒推……)

    $$f[i][j]=sum_{k=1}^{alpha}frac{1}{alpha}*(f[i+1][ch(j,k)]+[ch(j,k)==0])$$

    其中,ch(a,b)表示AC自动机中节点a+字符b转移到达的节点。

    最后用矩阵快速幂优化转移(加一个常数项)。

    听说炸精度,就不写代码了哈哈哈QwQ。

  • 相关阅读:
    我从Linux走来,选择了Windows
    静态路由(三路由)
    设置跨交换机VLAN
    服务器只能被动接受
    理解 atime,ctime,mtime (下)
    理解 atime,ctime,mtime (上)
    visualvm连接服务器jvm进行监控
    mysql 日期函数格式
    关于springmvc跨域
    Javassist初体验
  • 原文地址:https://www.cnblogs.com/onioncyc/p/8554591.html
Copyright © 2011-2022 走看看