数数 bzoj-3530 Sdoi-2014

题目大意:给你一个整数集合,求所有不超过n的正整数,是的它的十进制表示下不能再一段等于集合中的任意数。

注释:$1\le n \le 1200$,$1\le |S|\le 100$,$1\le L\le 1500$,L是总长度之和。

想法:咳咳,显然,我们... ...什么都不想,看着能开下先把AC自动机扔出来

然后,其实数位dp就可以了

具体看代码

最后,附上丑陋的代码... ...

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#define mod 1000000007
using namespace std;
typedef long long ll;
struct tree
{
int fail;
int vis[11];
int end;
}a[1600];
char s[1600],t[1250];
int n,m,cnt;
ll f[3][1250][1600],ans;
void build(char *s)
{
int l=strlen(s);
int now=0;
for(int i=0;i<l;i++)
{
int x=s[i]-'0';
if(!a[now].vis[x])
{
a[now].vis[x]=++cnt;
}
now=a[now].vis[x];
}
a[now].end|=1;
}
queue<int>q;
void getfail()
{
while(!q.empty()) q.pop();
for(int i=0;i<10;i++)
{
if(a[0].vis[i]!=0)
{
a[a[0].vis[i]].fail=0;
q.push(a[0].vis[i]);
}
}
while(!q.empty())
{
int now=q.front();q.pop();
for(int i=0;i<10;i++)
{
if(!a[now].vis[i])
{
a[now].vis[i]=a[a[now].fail].vis[i];
}
else
{
a[a[now].vis[i]].fail=a[a[now].fail].vis[i];
a[a[now].vis[i]].end|=a[a[a[now].fail].vis[i]].end;
q.push(a[now].vis[i]);
}
}
}
}
int main()
{
scanf("%s",t+1);
m=strlen(t+1);
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%s",s),build(s);
getfail();
for(int i=0;i<m;i++)
{
for(int j=0;j<=cnt;j++)
{
if(!j)
{
if(!i)
{
int x=t[i+1]-'0';
for(int k=1;k<x;k++)
{
if(!a[a[j].vis[k]].end)
{
f[1][i+1][a[j].vis[k]]+=1;
f[1][i+1][a[j].vis[k]]%=mod;
}
}
if(!a[a[j].vis[x]].end)
{
f[0][i+1][a[j].vis[x]]+=1;
f[0][i+1][a[j].vis[x]]%=mod;
}
}
else
{
for(int k=1;k<=9;k++)
{
if(!a[a[j].vis[k]].end)
{
f[1][i+1][a[j].vis[k]]++;
f[1][i+1][a[j].vis[k]]%=mod;
}
}
}
}
if(f[0][i][j])
{
int x=t[i+1]-'0';
for(int k=0;k<x;k++)
{
if(!a[a[j].vis[k]].end)
{
f[1][i+1][a[j].vis[k]]+=f[0][i][j];
f[1][i+1][a[j].vis[k]]%=mod;
}
}
if(!a[a[j].vis[x]].end)
{
f[0][i+1][a[j].vis[x]]+=f[0][i][j];
f[0][i+1][a[j].vis[x]]%=mod;
}
}
if(f[1][i][j])
{
for(int k=0;k<=9;k++)
{
if(!a[a[j].vis[k]].end)
{
f[1][i+1][a[j].vis[k]]+=f[1][i][j];
f[1][i+1][a[j].vis[k]]%=mod;
}
}
}
}
}
for(int i=0;i<=cnt;i++)
{
ans+=f[0][m][i];
ans%=mod;
ans+=f[1][m][i];
ans%=mod;
}
printf("%lld\n",ans);
return 0;
}

小结:我们在处理字符串问题的时候脑子里先有几个数据结构在搞事情.. ...

[bzoj3530][Sdoi2014]数数_AC自动机_数位dp的更多相关文章

  1. BZOJ_1662_[Usaco2006 Nov]Round Numbers 圆环数_数位DP

    BZOJ_1662_[Usaco2006 Nov]Round Numbers 圆环数_数位DP Description 正如你所知,奶牛们没有手指以至于不能玩“石头剪刀布”来任意地决定例如谁先挤奶的顺 ...

  2. BZOJ_1026_[SCOI2009]windy数_数位DP

    BZOJ_1026_[SCOI2009]windy数_数位DP 题意:windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之 ...

  3. BZOJ_1833_[ZJOI2010]count 数字计数_数位DP

    BZOJ_1833_[ZJOI2010]count 数字计数_数位DP 题意: 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. 分析: 数位DP f[i][ ...

  4. [bzoj1026][SCOI2009]windy数_数位dp

    windy数 bzoj-1026 题目大意:求一段区间中的windy数个数. 注释:如果一个数任意相邻两位的差的绝对值都不小于2,这个数就是windy数,没有前导0.$区间边界<=2\cdot ...

  5. [bzoj3209]花神的数论题_数位dp

    花神的数论题 bzoj-3209 题目大意:sum(i)表示i的二进制表示中1的个数,求$\prod\limits_{i=1}^n sum(i)$ 注释:$1\le n\le 10^{15}$. 想法 ...

  6. bzoj1026: [SCOI2009]windy数(传说你是数位DP)

    1026: [SCOI2009]windy数 题目:传送门 题解: 其实之前年少无知的时候好像A过...表示当时并不知道什么数位DP 今天回来深造一发... 其实如果对这个算法稍有了解...看到这题的 ...

  7. bzoj 3209 花神的数论题——二进制下的数位dp

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3209 可以枚举 “1的个数是...的数有多少个” ,然后就是用组合数算在多少位里选几个1. ...

  8. ZOJ 3494 (AC自动机+高精度数位DP)

    题目链接:  http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3494 题目大意:给定一些被禁止的BCD码.问指定范围内不含有 ...

  9. uva11038_How Many O's?_数位DP

    问m-n之间的数中共有多少个0,过程稍稍麻烦了一些,半天的时间才搞定. 直接上码吧 /********************************************************* ...

随机推荐

  1. 动态规划---状压dp

    状压dp,就是把动态规划之中的一个个状态用二进制表示,主要运用位运算. 这里有一道例题:蓝书P639猛兽军团1 [SCOI2005]互不侵犯 题目: 题目描述 在N×N的棋盘里面放K个国王,使他们互不 ...

  2. PCB 3D PCB 后续改进与扩展功能一些想法

    再次感受到WelGl实现3D效果的震撼, 一.目前功能: Gerber与钻孔 解析 并转为3D实景图,用户360度操控 二.后续改进扩展功能: 1.增加ODB++解析 2. 3D 尺寸标注(外形尺寸, ...

  3. thinkphp的session用法

    Session方法用于Session 设置.获取.删除和管理操作. Session 用于Session 设置.获取.删除和管理操作 用法 session($name, $value='') 参数 na ...

  4. Django day03 orm介绍

    一:orm介绍 就是对象关系映射,python当中的类能够对应到数据库当中的某一个表(一个类对应一个表),一个类的对象对应着数据库中的一条记录,类当中的某个字段对应着数据库当中表的字段,字段拥有不同的 ...

  5. PowerDesigner常用技巧

    PowerDesigner是非常强大的数据库设计软件,熟练使用PowerDesigner可以使数据库设计高效而简洁.PowerDesign具体操作在帮助文档(按F1)里面有详细描述,这儿只是列出了常用 ...

  6. RecastNavigation(3D场景建模、网格导航)

    一.RecastNavigation详解 RecastNavigation定义: RecastNavigation是一个导航寻路工具集,使用邻接的凸多边形集合描述一个3D场景,A*寻路算法使3D场景的 ...

  7. mysql数据库的介绍及安装

    一.什么是数据库 1.什么是数据(Data) 描述事物的符号记录成为数据,描述事物的符号既可以是文字.图片.图像.声音.语言等,数据有多种表现形式,他们都可以经过数字化后存入计算机 在计算机中描述一个 ...

  8. DOM 介绍

    什么时DOM DOM:文档对象模型.DOM为文档提供了结构化表示,并定义了如何通过脚本来范文文档结构.目的起始就是为了能让js操作html元素而指定的一个规范. DOM就是由节点组成的. 解析过程 H ...

  9. 【转载】cocos2dx 中 Android NDK 加载动态库的问题

     原文地址:http://blog.csdn.net/sozell/article/details/10551309 cocos2dx 中 Android NDK 加载动态库的问题 闲聊 最近在接入各 ...

  10. SQL Server中,with as使用介绍

    一.WITH AS的含义      WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到.有的时候 ...