http://www.lydsy.com/JudgeOnline/problem.php?id=3802

dp[i][0/1/2/3]  表示前i个字母,第1、2个字符串,第2、3个字符串的关系分别为 < < , = < , < = , = =

枚举前i-1个字母 构成的关系

再枚举3个字符串的字母 转移

时间复杂度为 O(N* 26^3)

优化转移:

转移都是dp[i-1][0/1/2/3]-->dp[i][0/1/2/3]

预处理出f[i][j][k][s:0~3][t:0~3] 表示前面字母构成的字符串的关系为s,3个字符串分别加上1个字母i、j、k后转移到关系t的方案数

转移的时候不枚举3个字符串的字母,枚举新的关系0~3

直接用f数组转移

#include<cstdio>
#include<cstring> using namespace std; #define N 1000002 const int mod=1e9+; char s1[N],s2[N],s3[N]; int f[][][][][];
int dp[N][];
//0:i<j<k 1:i=j<k 2:i<j=k 3:i=j=k void pre()
{
int li,ri,lj,rj,lk,rk;
int t;
for(int i=;i<=;++i)
for(int j=;j<=;++j)
for(int k=;k<=;++k)
{
if(i==) li=,ri=;
else li=ri=i;
if(j==) lj=,rj=;
else lj=rj=j;
if(k==) lk=,rk=;
else lk=rk=k;
for(int ci=li;ci<=ri;++ci)
for(int cj=lj;cj<=rj;++cj)
for(int ck=lk;ck<=rk;++ck)
for(int s=;s<=;++s)
{
if(!s) t=;
else if(s==)
{
if(ci==cj) t=;
else if(ci<cj) t=;
else t=-;
}
else if(s==)
{
if(cj==ck) t=;
else if(cj<ck) t=;
else t=-;
}
else
{
if(ci>cj || ci>ck || cj>ck) t=-;
else if(ci<cj && cj<ck) t=;
else if(ci==cj && cj<ck) t=;
else if(ci<cj && cj==ck) t=;
else t=;
}
if(t>=) f[i][j][k][s][t]++;
}
}
} int main()
{
pre();
int T;
scanf("%d",&T);
int l1,l2,l3,len;
int x,y,z;
while(T--)
{
scanf("%s",s1+);
scanf("%s",s2+);
scanf("%s",s3+);
l1=strlen(s1+);
len=l1;
l2=strlen(s2+);
if(l2>len) len=l2;
l3=strlen(s3+);
if(l3>len) len=l3;
while(l1!=len) s1[++l1]='a'-;
while(l2!=len) s2[++l2]='a'-;
while(l3!=len) s3[++l3]='a'-;
for(int i=;i<=len;++i)
for(int j=;j<=;++j)
dp[i][j]=;
dp[][]=;
for(int i=;i<=len;++i)
{
x=s1[i]-'a'+;
if(x<) x=;
y=s2[i]-'a'+;
if(y<) y=;
z=s3[i]-'a'+;
if(z<) z=;
for(int j=;j<=;++j)
if(dp[i-][j])
for(int k=;k<=;++k)
dp[i][k]=(dp[i][k]+(long long)dp[i-][j]*f[x][y][z][j][k]%mod)%mod;
}
printf("%d\n",dp[len][]);
}
}

3802: Vocabulary

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 185  Solved: 68
[Submit][Status][Discuss]

Description

给你三个字符串,这些字符串有些单词模糊不可认了,用"?"来代表。
现在你可以用任意英文小写字母来代表它们。要求是使得给定的三个字符串中
所有的"?"被你认定的字母代替后,各不相同且按字典序出现。问有多少种方式。
 

Input

先给出一个数字N,代表数据组数。
接下来3*N行,每行给出一个字符串。长度<=1000 000

Output

输出结果 Mod 10^9+9

Sample Input

3
?heoret?cal
c?mputer
?cience
jagiellonia
?niversity
kra?ow
?
b
c

Sample Output

42562
52
1

bzoj千题计划234:bzoj3802: Vocabulary的更多相关文章

  1. bzoj千题计划300:bzoj4823: [Cqoi2017]老C的方块

    http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...

  2. bzoj千题计划196:bzoj4826: [Hnoi2017]影魔

    http://www.lydsy.com/JudgeOnline/problem.php?id=4826 吐槽一下bzoj这道题的排版是真丑... 我还是粘洛谷的题面吧... 提供p1的攻击力:i,j ...

  3. bzoj千题计划280:bzoj4592: [Shoi2015]脑洞治疗仪

    http://www.lydsy.com/JudgeOnline/problem.php?id=4592 注意操作1 先挖再补,就是补的范围可以包含挖的范围 SHOI2015 的题 略水啊(逃) #i ...

  4. bzoj千题计划177:bzoj1858: [Scoi2010]序列操作

    http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...

  5. bzoj千题计划317:bzoj4650: [Noi2016]优秀的拆分(后缀数组+差分)

    https://www.lydsy.com/JudgeOnline/problem.php?id=4650 如果能够预处理出 suf[i] 以i结尾的形式为AA的子串个数 pre[i] 以i开头的形式 ...

  6. bzoj千题计划304:bzoj3676: [Apio2014]回文串(回文自动机)

    https://www.lydsy.com/JudgeOnline/problem.php?id=3676 回文自动机模板题 4年前的APIO如今竟沦为模板,,,╮(╯▽╰)╭,唉 #include& ...

  7. bzoj千题计划292:bzoj2244: [SDOI2011]拦截导弹

    http://www.lydsy.com/JudgeOnline/problem.php?id=2244 每枚导弹成功拦截的概率 = 包含它的最长上升子序列个数/最长上升子序列总个数 pre_len ...

  8. bzoj千题计划278:bzoj4590: [Shoi2015]自动刷题机

    http://www.lydsy.com/JudgeOnline/problem.php?id=4590 二分 这么道水题 没long long WA了两发,没判-1WA了一发,二分写错WA了一发 最 ...

  9. bzoj千题计划250:bzoj3670: [Noi2014]动物园

    http://www.lydsy.com/JudgeOnline/problem.php?id=3670 法一:KMP+st表 抽离nxt数组,构成一棵树 若nxt[i]=j,则i作为j的子节点 那么 ...

随机推荐

  1. Android与单片机通信常用数据转换方法(汇总)

    下面直接贴代码 1.  将GB2312转化为中文,如BAFAC2DCB2B7→胡萝卜,两个字节合成一个文字 public static String stringToGbk(String string ...

  2. install opencv 2.4.10 with issue :"nvcc fatal : Unsupported gpu architecture 'compute_11'"

    issue: nvcc fatal   : Unsupported gpu architecture 'compute_11'CMake Error at cuda_compile_generated ...

  3. 关于App自动化执行链接Appium服务包名正确但是报错An unknown server-side error occurred while processing the command

    在执行链接Appium服务时连接失败可能原因: 1.报错截图: 2.先检查包名是否正确(正常情况下包名不会错误)通过命令行查看包名:aapt dump badging xxx.apk 3.检查对应包的 ...

  4. GitHub 新手教程 三,Git Bash

    1,通过 开始菜单 启动 Git Bash,或者 在 cmd 下执行以下命令: D:\SoftWare\Git\git-bash.exe --cd-to-home (D:\SoftWare\Git 是 ...

  5. CSAPP lab2 二进制拆弹 binary bombs phase_3

    给出对应于7个阶段的7篇博客 phase_1  https://www.cnblogs.com/wkfvawl/p/10632044.htmlphase_2  https://www.cnblogs. ...

  6. Linux第一章读书笔记

    一.Linux历史 Unix强大的根本原因: 1.简洁,仅仅提供几百个系统调用并且有一个非常明确的设计目的 2.文件对待所有东西,通过一套相同的系统调用接口来进行对数据和设备的操作 3.由于用C语言编 ...

  7. Apache修改了配置文件中的路径后,登录该地址网页出现问题 (其中介绍了selinux的域和安全上下文)

    默认的网站数据存放在: /var/www/html 首页名称: index.html Apache服务程序的主配置文件: /etc/httpd/conf/httpd.conf (若是将  119  行 ...

  8. Beta阶段冲刺三

    Beta阶段冲刺三 Task1:团队TSP 团队任务 预估时间 实际时间 完成日期 新增其他学院的爬虫 180 130 11.30 新增其他学院的数据库字段修改 180 160 12.1 新增其他学院 ...

  9. Django时间时区问题(received a naive datetime while time zone support is active)

    在django1.4以后,存在两个概念 naive time 与 active time. 简单点讲,naive time就是不带时区的时间,Active time就是带时区的时间. 举例来说,使用d ...

  10. 2017-12 CDQZ集训(已完结)

    从联赛活了下来(虽然分数倒一……),接下来要去CDQZ集训啦…… DAY -2 2017-12-16 被老师安排负责一部分同学的住宿以及安排…… 抓紧时间继续学习,LCT真好玩啊真好玩…… 晚上放假了 ...