[Sdoi2014]数数

Time Limit: 10 Sec  Memory Limit: 512 MB
Submit: 1264  Solved: 636
[Submit][Status][Discuss]

Description

我们称一个正整数N是幸运数,当且仅当它的十进制表示中不包含数字串集合S中任意一个元素作为其子串。例如当S=(22,333,0233)时,233是幸运数,2333、20233、3223不是幸运数。
    给定N和S,计算不大于N的幸运数个数。

Input

输入的第一行包含整数N。
    接下来一行一个整数M,表示S中元素的数量。
    接下来M行,每行一个数字串,表示S中的一个元素。

Output

输出一行一个整数,表示答案模109+7的值。

Sample Input

20
3
2
3
14

Sample Output

14

HINT

下表中l表示N的长度,L表示S中所有串长度之和。

1 < =l < =1200 , 1 < =M < =100 ,1 < =L < =1500

Source

Round 1 day 1

AC自动机建好后f[i][j][k]表示i这个点j长度k=0表示小于,1表示等于

这样转移很好转移 IL的复杂度随便跑,

虑到不能有前导零,所以填每一位的时候可以把根节点单独转移一次1~9

 #pragma GCC optimzie(2)
#pragma G++ optimize(2)
#include<cstring>
#include<cmath>
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<queue> #define ll long long
#define N 2007
#define mod 1000000007
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return x*f;
} int m,len,l;
ll ans;
struct Node
{
int c[],suf;
bool flag;
}trie[N];
int cnt=,rt=;
ll f[][][];
char ch[N],n[N]; void insert()
{
int now=rt;
for (int i=;i<=len;i++)
if(trie[now].c[ch[i]-''])now=trie[now].c[ch[i]-''];
else
{
trie[now].c[ch[i]-'']=++cnt;
now=cnt;
}
trie[now].flag=true;
}
void make_AC()
{
for (int i=;i<;i++)
trie[].c[i]=;
queue<int>q;q.push();
trie[].suf=;
while(!q.empty())
{
int u=q.front();q.pop();
for (int i=;i<;i++)
if(trie[u].c[i])
{
trie[trie[u].c[i]].suf=trie[trie[u].suf].c[i];
if(trie[trie[trie[u].c[i]].suf].flag)trie[trie[u].c[i]].flag=true;
q.push(trie[u].c[i]);
}
else trie[u].c[i]=trie[trie[u].suf].c[i];
}
}
void solve()
{
/*f[0][1][1]=1;
for (int i=0;i<l;i++)
for (int j=1;j<=cnt;j++)
{
if (f[i][j][1]&&!trie[j].flag)
{
for (int k=0;k<10;k++)
if (n[i+1]-'0'>k)(f[i+1][trie[j].c[k]][0]+=f[i][j][1])%=mod;
else if(n[i+1]-'0'==k)(f[i+1][trie[j].c[k]][1]+=f[i][j][1])%=mod;
}
if(f[i][j][0]&&!trie[j].flag)
{
for (int k=0;k<10;k++)
(f[i+1][trie[j].c[k]][0]+=f[i][j][0])%=mod;
}
}*/
for (int i=;i<=l;i++)
{
for (int z=,v=trie[].c[z];z<=;v=trie[].c[++z])
{
if(i!=||z<n[i]-'')(f[i][v][]+=)%=mod;
else if(z==n[i]-'')(f[i][v][]+=)%=mod;
}
for (int j=;j<=cnt;j++)
if(!trie[j].flag)
for (int c=,v=trie[j].c[c];c<=;v=trie[j].c[++c])
{
(f[i][v][]+=f[i-][j][])%=mod;
if(c<n[i]-'')(f[i][v][]+=f[i-][j][])%=mod;
else if(c==n[i]-'')(f[i][v][]+=f[i-][j][])%=mod;
}
} for (int i=;i<=cnt;i++)
if(!trie[i].flag)(ans+=f[l][i][]+f[l][i][])%=mod;
printf("%lld",ans);
}
int main()
{
scanf("%s",n+);l=strlen(n+);
m=read();
for (int i=;i<=m;i++)
{
scanf("%s",ch+),len=strlen(ch+);
insert();
}
make_AC(),solve();
}

bzoj [Sdoi2014]数数 AC自动机上dp的更多相关文章

  1. 【Luogu】P3311数数(AC自动机上DP)

    题目链接 蒟蒻今天终于学会了AC自动机,感觉很稳 (后一句愚人节快乐) 这题开一个f[i][j][k]表示有没有受到限制,正在枚举第j位,来到了AC自动机的第k个节点 的方案数 随后可以刷表更新 注意 ...

  2. 【洛谷4045】[JSOI2009] 密码(状压+AC自动机上DP)

    点此看题面 大致题意: 给你\(n\)个字符串,问你有多少个长度为\(L\)的字符串,使得这些字符串都是它的子串.若个数不大于\(42\),按字典序输出所有方案. 状压 显然,由于\(n\)很小,我们 ...

  3. Passwords Gym - 101174E (AC自动机上DP)

    Problem E: Passwords \[ Time Limit: 1 s \quad Memory Limit: 256 MiB \] 题意 给出两个正整数\(A,B\),再给出\(n\)个字符 ...

  4. URAL 1158 AC自动机上的简单DP+大数

    题目大意 在一种语言中的字母表中有N(N<=50)个字母,每个单词都由M(M<=50)个字母构成,因此,一共可以形成N^M个单词.但是有P(P<=10)个串是被禁止的,也就是说,任何 ...

  5. bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp)

    bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp) bzoj Luogu 题解时间 给两个小写字母串 $ A $ , $ B $ ,请你计算: ...

  6. bzoj 2553 [BeiJing2011]禁忌——AC自动机+概率DP+矩阵

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2553 看了题解才会…… 首先,给定一个串,最好的划分方式是按禁忌串出现的右端点排序,遇到能填 ...

  7. 【JZOJ3624】【SDOI2014】数数(count) AC自动机+数位dp

    题面 100 容易想到使用AC自动机来处理禁忌子串的问题: 然后在自动机上数位dp,具体是: \(f_{i,j,0/1}\)表示填了\(i\)位,当前在自动机的第\(j\)个结点上,\(0\)表示当前 ...

  8. 【HDU3530】 [Sdoi2014]数数 (AC自动机+数位DP)

    3530: [Sdoi2014]数数 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 682  Solved: 364 Description 我们称一 ...

  9. BZOJ 1030 文本生成器 | 在AC自动机上跑DP

    题目: http://www.lydsy.com/JudgeOnline/problem.php?id=1030 题解: 鸽 #include<cstdio> #include<al ...

随机推荐

  1. 指定的参数已超出有效值的范围。 参数名: site

    “/”应用程序中的服务器错误. 指定的参数已超出有效值的范围.参数名: site 说明: 执行当前 Web 请求期间,出现未经处理的异常.请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的 ...

  2. 适配IE8+等浏览器的适配播放插件

    function myBrowser(){ var userAgent = navigator.userAgent; //ȡ���������userAgent�ַ� var isOpera = us ...

  3. TouTiao开源项目 分析笔记1

    1.InitApp==>项目的入口Application 1.1.继承了MultiDexApplication 超过65K方法的APP,会遇到65535的错误.原因就是为了支持比较大型的APP而 ...

  4. Android开发——View滑动的三种实现方式

    0. 前言   Android开发中,我们常常需要View滑动实现一些绚丽的效果来优化用户体验.一般View的滑动可以用三种方式实现. 转载请注明出处:http://blog.csdn.net/seu ...

  5. WIN8、WIN7访问Windows Server 2003服务器的数据库速度很慢、远程速度很慢的解决方法

    原因是微软在WIN7开始上加入了网络速度限制.在控制台执行以下命令即可解决: netsh interface tcp set global autotuninglevel=disabled

  6. 最“高大上”的Spring测试:Spring Test

    我想给大家介绍一款非常实用.且高端大气上档次的spring测试,在这里,我要强烈推荐使用Spring的Test Context框架,为什么呢?俗话说,“货比三家不上当”,要搞清楚这个问题,我们先来看一 ...

  7. 去掉referer信息

    <iframe src="auto-refresh.html" width=500 height=500 rel="noreferrer">< ...

  8. 七夕蠕虫“XX神器”逆向分析

    转载请注明出处 ____________________________________________________________________________________________ ...

  9. SecureCRT自动登录跳板机/堡垒机并连接目标机器

    公司登录目标服务器,需要先登录跳板机(堡垒机),然后再登录目标机器,一共需要4.5步. MAC或LINUX机器可以写.SH脚本,那WINDOWS有没有一键登陆的方法呢? 常用的SecureCRT工具就 ...

  10. JMeter学习笔记(十) 计数器

    前面写了导出文件接口的测试,对于导出文件的文件名称,为了不重复(即不覆盖之前的文件),可以添加一个计数器来设置不同的index,另外也可以借助函数助手. 下面是我使用到的关于计数器的简单应用,其他的自 ...