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

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

题意:\(\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

转载于:https://www.cnblogs.com/candy99/p/6666613.html

你可能感兴趣的文章
【loj6029】「雅礼集训 2017 Day1」市场 线段树+均摊分析
查看>>
在Linux上下载和安装AAC音频编码器FAAC
查看>>
我们为什么在移动端项目中选择jQuery而不是Zepto
查看>>
如何自定义 maven中的archetype
查看>>
有趣的网站
查看>>
vue+django2.0.2-rest-framework 生鲜项目(四)
查看>>
Laravel-china社区学习
查看>>
[转]c++类的大小
查看>>
查看ORACLE 数据库及表信息
查看>>
Beta 冲刺 (4/7)
查看>>
bzoj 5252: [2018多省省队联测]林克卡特树
查看>>
Mybatis缓存
查看>>
使用mysql(6部曲)
查看>>
leetcode 217—Contains Duplicate
查看>>
Vue基础知识之组件及组件之间的数据传递(五)
查看>>
https 学习笔记三
查看>>
Biopython 安装使用
查看>>
20155228 2016-2017-2 《Java程序设计》第10周学习总结
查看>>
QT1.1-与Opencv的hello world
查看>>
无意间把你的个人资料当圣诞礼物,送给了网络犯罪份子吗?
查看>>