分析:与poj的2778差不多的,求出来所有的情况然后减去不包含的就行了,这次使用了一下kuangbin的那种自动机写法,确实还不错,因为尤是在建立矩阵的时候更加方便。

 
代码如下:
===============================================================================================================================
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#include<iostream>
using namespace std; const int MAXN = ;
const int MAXM = ;
const int mod = ; struct Matrix
{///定义矩阵
int size;
unsigned long long edge[MAXN][MAXN]; Matrix(int Len)
{
size = Len;
memset(edge, false, sizeof(edge));
}
Matrix operator *(const Matrix &Map) const
{
Matrix ans(size); for(int i=; i<size; i++)
for(int j=; j<size; j++)
for(int k=; k<size; k++)
{
ans.edge[i][j] += edge[i][k] * Map.edge[k][j];
} return ans;
}
}; struct Ac_Trie
{
int next[MAXN][MAXM];
int fail[MAXN], End[MAXN];
int Len, root; Ac_Trie()
{
memset(next, -, sizeof(next));
memset(End, false, sizeof(End));
Len = , root = ;
} void Insert(char s[])
{
int p = root; for(int i=; s[i]; i++)
{
int k = s[i] - 'a'; if(next[p][k] == -)
next[p][k] = Len++;
p = next[p][k];
} End[p] = true;
} void GetFail()
{
queue<int> Q;
int p = root; fail[p] = root; for(int i=; i<MAXM; i++)
{
if(next[p][i] == -)
next[p][i] = root;
else
{
fail[next[p][i]] = root;
Q.push(next[p][i]);
}
} while(Q.size())
{
p = Q.front();
Q.pop(); for(int i=; i<MAXM; i++)
{
if(next[p][i] == -)
next[p][i] = next[fail[p]][i];
else
{
fail[next[p][i]] = next[fail[p]][i];
Q.push(next[p][i]);
}
} End[p] |= End[fail[p]];
}
} Matrix GetMatrix()
{
Matrix ans(Len+); for(int i=; i<Len; i++)
for(int k=; k<MAXM; k++)
{
if(End[next[i][k]] == false)
ans.edge[i][next[i][k]] += ;
} for(int i=; i<=Len; i++)
ans.edge[i][Len] = ; return ans;
}
}; Matrix QuickPow(long long K, Matrix Map)
{
Matrix ans(Map.size); for(int i=; i<ans.size; i++)
ans.edge[i][i] = ; while(K)
{
if(K & )
ans = ans * Map;
Map = Map * Map; K /= ;
} return ans;
} int main()
{
long long N, L; while(scanf("%lld%lld", &N, &L) != EOF)
{
char s[MAXN];
Ac_Trie a; while(N--)
{
scanf("%s", s);
a.Insert(s);
} a.GetFail();
Matrix ans = a.GetMatrix(); unsigned long long sum1=, sum=; ans = QuickPow(L, ans); for(int i=; i<ans.size; i++)
sum1 += ans.edge[][i]; ans.size = ;
ans.edge[][] = ;
ans.edge[][] = ;
ans.edge[][] = ans.edge[][] = ; ans = QuickPow(L, ans); sum = ans.edge[][] + ans.edge[][]; cout << sum - sum1 <<endl;
} return ;
}

考研路茫茫--单词情结 - HDU 2243(AC自动机+矩阵乘法)的更多相关文章

  1. 考研路茫茫――单词情结 HDU - 2243(ac自动机 + 矩阵快速幂)

    考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  2. 考研路茫茫——单词情结 HDU - 2243 AC自动机 && 矩阵快速幂

    背单词,始终是复习英语的重要环节.在荒废了3年大学生涯后,Lele也终于要开始背单词了. 一天,Lele在某本单词书上看到了一个根据词根来背单词的方法.比如"ab",放在单词前一般 ...

  3. POJ - 2778 ~ HDU - 2243 AC自动机+矩阵快速幂

    这两题属于AC自动机的第二种套路通过矩阵快速幂求方案数. 题意:给m个病毒字符串,问长度为n的DNA片段有多少种没有包含病毒串的. 根据AC自动机的tire图,我们可以获得一个可达矩阵. 关于这题的t ...

  4. hdu 2243 考研路茫茫——单词情结(AC自动+矩阵)

    考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. HDU 2243 考研路茫茫——单词情结(AC自动机+矩阵)

    考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  6. HDU 2243 考研路茫茫——单词情结

    考研路茫茫——单词情结 Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID ...

  7. hdu_2243_考研路茫茫——单词情结(AC自动机+矩阵)

    题目链接:hdu_2243_考研路茫茫——单词情结 题意: 让你求包含这些模式串并且长度不小于L的单词种类 题解: 这题是poj2788的升级版,没做过的强烈建议先做那题. 我们用poj2778的方法 ...

  8. hdu2243 考研路茫茫——单词情结【AC自动机】【矩阵快速幂】

    考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  9. HDU2243 考研路茫茫——单词情结 ——AC自动机、矩阵优化

    题目链接:https://vjudge.net/problem/HDU-2243 考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others)    Memor ...

随机推荐

  1. ASP 调用dll(VB)及封装dll实例

    ASP调用dll及封装dll实例,封装为dll可以提供运行效率,加密代码. 打开VB6,新建ActiveX DLL 2.在工程引用中加入Microsoft Active Server Pages Ob ...

  2. Orace数据库锁表的处理与总结<摘抄与总结一>

    TM锁(表级锁)类型共有5种,分别称为共享锁(S锁).排它锁(X锁).行级共享锁(RS锁).行级排它锁(RX锁).共享行级排它锁(SRX锁) 当Oracle执行DML语句时,系统自动在所要操作的表上申 ...

  3. 网络编程(学习整理)---2--(Udp)实现简单的控制台聊天室

    1.UDP协议: 总结一下,今天学习的一点知识点! UDP也是一种通信协议,常被用来与TCP协议作比较!我们知道,在发送数据包的时候使用TCP协议比UDP协议安全,那么到底安全在哪里呢?怎么理解呢! ...

  4. 【POJ1568】【极大极小搜索+alpha-beta剪枝】Find the Winning Move

    Description 4x4 tic-tac-toe is played on a board with four rows (numbered 0 to 3 from top to bottom) ...

  5. 命令模式(Command)

    1.本质: 封装请求 2.定义: 把一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化,对请求排队或记录请求日志,以及支持可撤销的操作 3.核心: 原本“行为请求者”和“行为执行者”是紧紧 ...

  6. php基础知识【函数】(4)时间date

    一.time() -- 返回当前的 Unix 时间戳 $nextWeek = time() + (7 * 24 * 60 * 60); echo 'Next Week: '. date('Y-m-d' ...

  7. github 分支 合并

    Git如何进行分支管理?      1.创建分支      创建分支很简单:git branch <分支名>      2.切换分支      git checkout <分支名&g ...

  8. 使用jQuery动态加载js脚本文件的方法

    动态加载Javascript是一项非常强大且有用的技术.这方面的主题在网上已经讨论了不少,我也经常会在一些个人项目上使用RequireJS和Dojo加载js 它们很强大,但有时候也会得不偿失.如果你使 ...

  9. IOS网络编程:HTTP

    IOS网络编程:HTTP HTTP定义了一种在服务器和客户端之间传递数据的途径. URL定义了一种唯一标示资源在网络中位置的途径. REQUESTS 和 RESPONSES: 客户端先建立一个TCP连 ...

  10. iOS的launch image --备用

    当我们打开一款应用程序的时候,首先映入眼帘的往往并不是程序的主界面,而是经过精心设计的欢迎界面,这个界面通常会停留几秒钟,然后消失.看似很平常的一个小小的欢迎界面,其实还大有讲究. 一.为什么会出现欢 ...