博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ 3530: [Sdoi2014]数数 [AC自动机 数位DP]
阅读量:6072 次
发布时间:2019-06-20

本文共 1421 字,大约阅读时间需要 4 分钟。

题意:\(\le N\)的不含模式串的数字有多少个,\(n=|N| \le 1200\)


考虑数位DP

对于长度\(\le n\)的,普通套路DP\(g[i][j]\)即可

对于长度\(=n\)的,需要考虑天际线,\(f[i][j][0/1]\)表示从高开始i位走到节点j,是否卡上界的方案数

需要注意的是前导0的处理,不能出现前导0,所以\(f[0]\)往外转移的时候不能走0

#include 
#include
#include
#include
#include
using namespace std;const int N=2005, P=1e9+7;typedef long long ll;inline int read(){ char c=getchar();int x=0,f=1; while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();} while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();} return x*f;}int n, m;char a[N], s[N];inline void mod(int &x) {if(x>=P) x-=P;}namespace ac{ struct meow{int ch[10], fail, val;}t[N]; int sz; void insert(char *s) { int len=strlen(s+1), u=0; for(int i=1; i<=len; i++) { int c=s[i]-'0'; if(!t[u].ch[c]) t[u].ch[c] = ++sz; u=t[u].ch[c]; } t[u].val=1; } int q[N], head, tail; void build() { head=tail=1; for(int i=0; i<10; i++) if(t[0].ch[i]) q[tail++]=t[0].ch[i]; while(head!=tail) { int u=q[head++]; t[u].val |= t[t[u].fail].val; for(int i=0; i<10; i++) { int &v=t[u].ch[i]; if(!v) v = t[t[u].fail].ch[i]; else t[v].fail = t[t[u].fail].ch[i], q[tail++]=v; } } } int f[N][N][2], g[N][N], ans; void dp() { g[0][0]=1; for(int i=0; i

转载地址:http://otngx.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
多线程之线程池任务管理通用模板
查看>>
CSS3让长单词与URL地址自动换行——word-wrap属性
查看>>
CodeForces 580B Kefa and Company
查看>>
开发规范浅谈
查看>>
Spark Streaming揭秘 Day29 深入理解Spark2.x中的Structured Streaming
查看>>
鼠标增强软件StrokeIt使用方法
查看>>
本地连接linux虚拟机的方法
查看>>
某公司面试java试题之【二】,看看吧,说不定就是你将要做的题
查看>>
BABOK - 企业分析(Enterprise Analysis)概要
查看>>
Linux 配置vnc,开启linux远程桌面
查看>>
NLog文章系列——如何优化日志性能
查看>>
Hadoop安装测试简单记录
查看>>
CentOS6.4关闭触控板
查看>>
ThreadPoolExecutor线程池运行机制分析-线程复用原理
查看>>
React Native 极光推送填坑(ios)
查看>>
Terratest:一个用于自动化基础设施测试的开源Go库
查看>>
修改Windows远程终端默认端口,让服务器更安全
查看>>
扩展器必须,SAS 2.0未必(SAS挺进中端存储系统之三)
查看>>
Eclipse遇到Initializing Java Tooling解决办法
查看>>