考研路茫茫--单词情结 - HDU 2243(AC自动机+矩阵乘法)
分析:与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自动机+矩阵乘法)的更多相关文章
- 考研路茫茫――单词情结 HDU - 2243(ac自动机 + 矩阵快速幂)
考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- 考研路茫茫——单词情结 HDU - 2243 AC自动机 && 矩阵快速幂
背单词,始终是复习英语的重要环节.在荒废了3年大学生涯后,Lele也终于要开始背单词了. 一天,Lele在某本单词书上看到了一个根据词根来背单词的方法.比如"ab",放在单词前一般 ...
- POJ - 2778 ~ HDU - 2243 AC自动机+矩阵快速幂
这两题属于AC自动机的第二种套路通过矩阵快速幂求方案数. 题意:给m个病毒字符串,问长度为n的DNA片段有多少种没有包含病毒串的. 根据AC自动机的tire图,我们可以获得一个可达矩阵. 关于这题的t ...
- hdu 2243 考研路茫茫——单词情结(AC自动+矩阵)
考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 2243 考研路茫茫——单词情结(AC自动机+矩阵)
考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 2243 考研路茫茫——单词情结
考研路茫茫——单词情结 Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID ...
- hdu_2243_考研路茫茫——单词情结(AC自动机+矩阵)
题目链接:hdu_2243_考研路茫茫——单词情结 题意: 让你求包含这些模式串并且长度不小于L的单词种类 题解: 这题是poj2788的升级版,没做过的强烈建议先做那题. 我们用poj2778的方法 ...
- hdu2243 考研路茫茫——单词情结【AC自动机】【矩阵快速幂】
考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU2243 考研路茫茫——单词情结 ——AC自动机、矩阵优化
题目链接:https://vjudge.net/problem/HDU-2243 考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others) Memor ...
随机推荐
- 多线程 - 线程同步锁(lock、Monitor)
1. 前言 多线程编程的时候,我们不光希望两个线程间能够实现逻辑上的先后顺序运行,还希望两个不相关的线程在访问同一个资源的时候,同时只能有一个线程对资源进行操作,否则就会出现无法预知的结果. 比如,有 ...
- 纯命令行教你Cocoapods的安装和使用
关于cocoapods的介绍和作用,网上有很多大神介绍的比我清楚,建议去看一下唐巧的http://blog.devtang.com/blog/2014/05/25/use-cocoapod-to-ma ...
- office2010怎么激活
软件都是不断更新换代的,像我们使用最多的Microsoft Office软件,从最初的98,2000,2003,2007,到现在的2010.但是在最初安装Office软件时,都是未激活的.下面介绍的就 ...
- C# div、css
目录: 1.Div+Css布局教程(-)CSS必备知识 注:本教程要求对html和css有基础了解. 一.CSS布局属性 Width:设置对象的宽度(width:45px). Height:设置对象的 ...
- [转]mysql导入导出数据中文乱码解决方法小结
本文章总结了mysql导入导出数据中文乱码解决方法,出现中文乱码一般情况是导入导入时编码的设置问题,我们只要把编码调整一致即可解决此方法,下面是搜索到的一些方法总结,方便需要的朋友. linux系统中 ...
- Javascript的AMD规范
Javascript发展到今天,已经从一个小丑语言变成了不可替代的前端利器,已经脱离了低端的玩笑脚步,而转变为有规可依的强大语言. 本文主要讲述下如今被大力推广的AMD规范,为什么要AMD,什么场景是 ...
- HttpClient的get+post请求使用
啥都不说,先上代码 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReade ...
- 【BZOJ2049】【LCT】Cave 洞穴勘测
Description 辉 辉热衷于洞穴勘测.某天,他按照地图来到了一片被标记为JSZX的洞穴群地区.经过初步勘测,辉辉发现这片区域由n个洞穴(分别编号为1到n)以及若干通 道组成,并且每条通道连接了 ...
- phpcms(4) V9 栏目管理
phpcms V9框架系统后台管理之栏目管理,请参见下文的源码分析(添加栏目和修改栏目): 参照添加栏目的界面图示,便于对源代码的理解: <?php // 文件路径:phpcms/modul ...
- 那些年被我坑过的Python——道阻且长(第五章实用模块讲解)
random模块 我的随机验证吗程序: 首先保证了字母和数字出现的概率是50% VS 50%,其次是可以订制输出多少位 def Captcha(size): Captcha_list = [] for ...