题意:求一个长度为n的数字字符串 (n <= 1e9)

   不出现子串s的方案数

题解:用f i,j表示长度为i匹配到在子串j的答案

   用kmp的失配函数预处理一下 然后这个转移每一个都是一样的 所以可以用矩阵加速

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3.  
  4. int n, m, mod;
  5. char s[];
  6. int fail[];
  7.  
  8. struct node {
  9. int c[][];
  10. }a, re;
  11.  
  12. node mul(node x, node y) {
  13. node res;
  14. memset(res.c, , sizeof(res.c));
  15.  
  16. for(int i = ; i < m; i++)
  17. for(int j = ; j < m; j++)
  18. for(int k = ; k < m; k++)
  19. res.c[i][j] = (res.c[i][j] + x.c[i][k] * y.c[k][j] % mod) % mod;
  20. return res;
  21. }
  22.  
  23. node pow_mod(node x, int y) {
  24. node res;
  25. memset(res.c, , sizeof(res.c));
  26. for(int i = ; i < m; i++) res.c[i][i] = ;
  27.  
  28. while(y) {
  29. if(y & ) res = mul(res, x);
  30. x = mul(x, x);
  31. y >>= ;
  32. }
  33. return res;
  34. }
  35.  
  36. int main() {
  37. scanf("%d%d%d", &n, &m, &mod);
  38. scanf("%s", s + );
  39.  
  40. fail[] = fail[] = ;
  41. for(int i = ; i <= m; i++) {
  42. int j = fail[i - ];
  43. while(j && s[i] != s[j + ]) j = fail[j];
  44. fail[i] = s[i] == s[j + ] ? j + : ;
  45. }
  46.  
  47. for(int i = ; i < m; i++) {
  48. for(int j = ; j < ; j++) {
  49. int k = i;
  50. while(k && (s[k + ] - '') != j) k = fail[k];
  51. if(s[k + ] - '' == j) k++;
  52. if(k != m) a.c[i][k] = (a.c[i][k] + ) % mod;
  53. }
  54. }
  55.  
  56. re = pow_mod(a, n);
  57. int ans = ;
  58. for(int i = ; i < m; i++) ans = (ans + re.c[][i]) % mod;
  59.  
  60. printf("%d\n", ans);
  61. return ;
  62. }

BZOJ1009: [HNOI2008]GT考试 (矩阵快速幂 + DP)的更多相关文章

  1. BZOJ1009: [HNOI2008]GT考试 矩阵快速幂+kmp+dp

    这个题你发现打暴力的话可以记忆化搜素加剪枝,那么意味着可以递推,我们搜的话就是1010^9我们就往下匹配遇到匹配成功就return,那么我们可以想一下什么决定了状态,我们考虑kmp的过程,对于我们目前 ...

  2. BZOJ 1009 [HNOI2008]GT考试(矩阵快速幂优化DP+KMP)

    题意: 求长度为n的不含长为m的指定子串的字符串的个数 1s, n<=1e9, m<=50 思路: 长见识了.. 设那个指定子串为s f[i][j]表示长度为i的字符串(其中后j个字符与s ...

  3. BZOJ1009 矩阵快速幂+DP+KMP

    Problem 1009. -- [HNOI2008]GT考试 1009: [HNOI2008]GT考试 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: ...

  4. BZOJ1009 [HNOI2008]GT考试 矩阵

    去博客园看该题解 题目 [bzoj1009][HNOI2008]GT考试 Description 阿申准备报名参加GT考试,准考证号为N位数X1X2….Xn(0<=Xi<=9),他不希望准 ...

  5. codeforces 691E 矩阵快速幂+dp

    传送门:https://codeforces.com/contest/691/problem/E 题意:给定长度为n的序列,从序列中选择k个数(可以重复选择),使得得到的排列满足xi与xi+1异或的二 ...

  6. P1357 花园 (矩阵快速幂+ DP)

    题意:一个只含字母C和P的环形串 求长度为n且每m个连续字符不含有超过k个C的方案数 m <= 5  n <= 1e15 题解:用一个m位二进制表示状态 转移很好想 但是这个题是用矩阵快速 ...

  7. Codeforces 576D Flights for Regular Customers 矩阵快速幂+DP

    题意: 给一个$n$点$m$边的连通图 每个边有一个权值$d$ 当且仅当当前走过的步数$\ge d$时 才可以走这条边 问从节点$1$到节点$n$的最短路 好神的一道题 直接写做法喽 首先我们对边按$ ...

  8. COJ 1208 矩阵快速幂DP

    题目大意: f(i) 是一个斐波那契数列 , 求sum(f(i)^k)的总和 由于n极大,所以考虑矩阵快速幂加速 我们要求解最后的sum[n] 首先我们需要思考 sum[n] = sum[n-1] + ...

  9. Codeforces 954 dijsktra 离散化矩阵快速幂DP 前缀和二分check

    A B C D 给你一个联通图 给定S,T 要求你加一条边使得ST的最短距离不会减少 问你有多少种方法 因为N<=1000 所以N^2枚举边数 迪杰斯特拉两次 求出Sdis 和 Tdis 如果d ...

随机推荐

  1. 怎样让自定义Cell的图片和文本自适应高度

    Let's do it! 首先创建一个Model类 包括一个图片名称属性 还有文字内容属性 #import <Foundation/Foundation.h> @interface Mod ...

  2. test markdown style

    code // Forward declaration of isBadVersion API. bool isBadVersion(int version); class Solution { pu ...

  3. DOM0、DOM2级事件

    JavaScript DOM0.DOM2级事件 1.DOM0级事件:on+事件类型 在html行内直接绑定,也就是通过行内js绑定的例如<span onclick="alert('1' ...

  4. springboot与shiro和mybatis和mysql

    测试项目已上传到GitHub:https://github.com/xiaostudy/springboot_shiro_test1 1.创建springboot项目 <!-- 数据库连接池 - ...

  5. 笔记-JavaWeb学习之旅4

    JDBC: 概念:Java DataBase Connectivity Java 数据库连接,Java语言操作数据库 本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口,各个数 ...

  6. (十四)SpringBoot开发微信授权支付

    前提:配置好域名,在公众号配置 一.引用jar包,在pom.xml文件加入依赖 <dependency> <groupId>com.github.binarywang</ ...

  7. C 语言实例 - 连接字符串

    C 语言实例 - 连接字符串 C 语言实例 C 语言实例 使用 strcat() 连接两个字符串. 实例 #include <stdio.h> int main() { ], s2[], ...

  8. [题解](最短路(树))luogu_P5201_short cut

    一开始想着最短路时统计一下到每个点的牛数量,但是没写出来 建最短路树是个不错的想法,正常跑一次最短路,枚举每个点的前驱,如果d[y]==d[x]+w就是树上的一条边,优先连编号小的, 建好树以后做一次 ...

  9. 洛谷 P2623 物品选取

    https://www.luogu.org/problemnew/show/P2623 https://www.luogu.org/blog/test-1/solution-p2623 重点就是甲类物 ...

  10. StretchDIBits速度测试(HALFTONE)

    StretchDIBits速度测试(HALFTONE) 下面实验中显示窗口大小为1024*768,拉伸模式设为HALFTONE. 一.单通道图像 (1) 保持图像高度为1024,宽度从24到2024递 ...