bzoj [Sdoi2014]数数 AC自动机上dp
[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
3
2
3
14
Sample Output
HINT
下表中l表示N的长度,L表示S中所有串长度之和。
1 < =l < =1200 , 1 < =M < =100 ,1 < =L < =1500
Source
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的更多相关文章
- 【Luogu】P3311数数(AC自动机上DP)
题目链接 蒟蒻今天终于学会了AC自动机,感觉很稳 (后一句愚人节快乐) 这题开一个f[i][j][k]表示有没有受到限制,正在枚举第j位,来到了AC自动机的第k个节点 的方案数 随后可以刷表更新 注意 ...
- 【洛谷4045】[JSOI2009] 密码(状压+AC自动机上DP)
点此看题面 大致题意: 给你\(n\)个字符串,问你有多少个长度为\(L\)的字符串,使得这些字符串都是它的子串.若个数不大于\(42\),按字典序输出所有方案. 状压 显然,由于\(n\)很小,我们 ...
- Passwords Gym - 101174E (AC自动机上DP)
Problem E: Passwords \[ Time Limit: 1 s \quad Memory Limit: 256 MiB \] 题意 给出两个正整数\(A,B\),再给出\(n\)个字符 ...
- URAL 1158 AC自动机上的简单DP+大数
题目大意 在一种语言中的字母表中有N(N<=50)个字母,每个单词都由M(M<=50)个字母构成,因此,一共可以形成N^M个单词.但是有P(P<=10)个串是被禁止的,也就是说,任何 ...
- bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp)
bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp) bzoj Luogu 题解时间 给两个小写字母串 $ A $ , $ B $ ,请你计算: ...
- bzoj 2553 [BeiJing2011]禁忌——AC自动机+概率DP+矩阵
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2553 看了题解才会…… 首先,给定一个串,最好的划分方式是按禁忌串出现的右端点排序,遇到能填 ...
- 【JZOJ3624】【SDOI2014】数数(count) AC自动机+数位dp
题面 100 容易想到使用AC自动机来处理禁忌子串的问题: 然后在自动机上数位dp,具体是: \(f_{i,j,0/1}\)表示填了\(i\)位,当前在自动机的第\(j\)个结点上,\(0\)表示当前 ...
- 【HDU3530】 [Sdoi2014]数数 (AC自动机+数位DP)
3530: [Sdoi2014]数数 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 682 Solved: 364 Description 我们称一 ...
- BZOJ 1030 文本生成器 | 在AC自动机上跑DP
题目: http://www.lydsy.com/JudgeOnline/problem.php?id=1030 题解: 鸽 #include<cstdio> #include<al ...
随机推荐
- linux下Tomcat配置提示权限不够解决办法
在终端输入命令 sudo chmod -R 777 /opt/Tomcat,那么Tomcat文件夹和它下面的所有子文件夹的属性都变成了777(读/写/执行权限)
- tomcat 无论如何都无法创建新的Servers
1.退出eclipse 2.到[工程目录下 workspace ]/.metadata/.plugins/org.eclipse.core.runtime 3.把org.eclipse.wst.ser ...
- [洛谷1156]垃圾陷阱(DP)
[Luogu1156] f[i]表示高度为i时的存活时间 Code #include <cstdio> #include <algorithm> #define N 110 u ...
- 13、python中的函数(闭包与装饰器)
一.嵌套函数 函数的内部又再定义另一个函数,这个函数就叫嵌套函数,里面含函数就叫内部函数. 示例: 二.返回函数 函数可以接收函数对象作为参数,同理函数也能返回一个函数对象作为返回值. 示例: 返回函 ...
- http与www服务精解
TCP/IP 协议介绍 在介绍 HTTP 协议之前,先简单说一下TCP/IP协议的相关内容.TCP/IP协议是分层的,从底层至应用层分别为:物理层.链路层.网络层.传输层和应用层,如下图所示: 从应用 ...
- P1418 选点问题(黑白染色)
P1418 选点问题 题目描述 给出n个点,m条边,每个点能控制与其相连的所有的边,要求选出一些点,使得这些点能控制所有的边,并且点数最少.同时,任意一条边不能被两个点控制 输入输出格式 输入格式: ...
- P3819 松江1843路(洛谷月赛)
P3819 松江1843路 题目描述 涞坊路是一条长L米的道路,道路上的坐标范围从0到L,路上有N座房子,第i座房子建在坐标为x[i]的地方,其中住了r[i]人. 松江1843路公交车要在这条路上建一 ...
- android onCreate的两个方法
override fun onCreate(savedInstanceState: Bundle?, persistentState: PersistableBundle?) { } override ...
- html5兼容处理&sublime text3配置html5环境
1.为了兼容低版本的浏览器解析不了hmtl5标签,要在html文件中head内引入html5shiv.min.js文件 <!--[if lt IE 9]> <script src=& ...
- 【转】灰色在PPT中的运用
一.作为背景 灰色作为背景能够有效烘托其他元素,特别是与白/黑色渐变,效果更好. 1.黑灰渐变,科技感十足 2.纯灰:简单清晰 http://www.behance.net/gallery/N ...