题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2604

递推式是百度的,主要是练习一下如何使用矩阵快速幂优化。

递推式:f(n)=f(n-1)+f(n-3)+f(n-4),其中f(0)=2, f(1)=4, f(2)=6, f(3)=9。

当n>4时候,需要通过这个关系来递推。

构造矩阵这种东西我以前一直认为是很玄学的,但是如果深入研究的话不难发现其实也有规律可循。这是一个齐次递推式,很好构造。

我们希望通过如下矩阵(1)得到矩阵(2)

  1. | f(n) | |f(n+)|
  2. |f(n-)| | f(n) |
  3. |f(n-)| |f(n-)|
  4. |f(n-)| |f(n-)|
  5. () ()

那么实际上,我们是通过一个转换矩阵把f(n),f(n-1),f(n-2)移动了一下位置,并且推出了f(n+1)。再考虑到矩阵乘法的特性,我们就能得到一个递推矩阵:

  1. | |
  2. | |
  3. | |
  4. | |

我把第一行列为递推方程的系数,这样递推矩阵的第一列和目标矩阵的整列相乘即可得到递推的下一个结果。那剩下的怎么办呢?向下看会发现,按照行x列的特性,分别又列到了对应的位置。再根据矩阵乘法的性质就会很容易证明满足递推方程。

代码如下:

  1. #include <algorithm>
  2. #include <iostream>
  3. #include <iomanip>
  4. #include <cstring>
  5. #include <climits>
  6. #include <complex>
  7. #include <fstream>
  8. #include <cassert>
  9. #include <cstdio>
  10. #include <bitset>
  11. #include <vector>
  12. #include <deque>
  13. #include <queue>
  14. #include <stack>
  15. #include <ctime>
  16. #include <set>
  17. #include <map>
  18. #include <cmath>
  19.  
  20. using namespace std;
  21.  
  22. const int maxn = ;
  23. typedef struct Matrix {
  24. int m[maxn][maxn];
  25. int r;
  26. int c;
  27. Matrix(){
  28. r = c = ;
  29. memset(m, , sizeof(m));
  30. }
  31. } Matrix;
  32.  
  33. Matrix mul(Matrix m1, Matrix m2, int mod) {
  34. Matrix ans = Matrix();
  35. ans.r = m1.r;
  36. ans.c = m2.c;
  37. for(int i = ; i <= m1.r; i++) {
  38. for(int j = ; j <= m2.r; j++) {
  39. for(int k = ; k <= m2.c; k++) {
  40. if(m2.m[j][k] == ) continue;
  41. ans.m[i][k] = ((ans.m[i][k] + m1.m[i][j] * m2.m[j][k] % mod) % mod) % mod;
  42. }
  43. }
  44. }
  45. return ans;
  46. }
  47.  
  48. Matrix quickmul(Matrix m, int n, int mod) {
  49. Matrix ans = Matrix();
  50. for(int i = ; i <= m.r; i++) {
  51. ans.m[i][i] = ;
  52. }
  53. ans.r = m.r;
  54. ans.c = m.c;
  55. while(n) {
  56. if(n & ) {
  57. ans = mul(m, ans, mod);
  58. }
  59. m = mul(m, m, mod);
  60. n >>= ;
  61. }
  62. return ans;
  63. }
  64.  
  65. int n, m;
  66.  
  67. int main() {
  68. // freopen("in", "r", stdin);
  69. while(~scanf("%d %d", &n, &m)) {
  70. Matrix p;
  71. p.r = , p.c = ;
  72. p.m[][] = ;
  73. p.m[][] = ;
  74. p.m[][] = ;
  75. p.m[][] = ;
  76. if(n <= ) {
  77. printf("%d\n", p.m[-n+][] % m);
  78. continue;
  79. }
  80. Matrix s;
  81. s.r = s.c = ;
  82. s.m[][] = ; s.m[][] = , s.m[][] = , s.m[][] = ;
  83. s.m[][] = ; s.m[][] = , s.m[][] = , s.m[][] = ;
  84. s.m[][] = ; s.m[][] = , s.m[][] = , s.m[][] = ;
  85. s.m[][] = ; s.m[][] = , s.m[][] = , s.m[][] = ;
  86. s = quickmul(s, n-, m);
  87. int ans = ;
  88. for(int i = ; i <= p.r; i++) {
  89. ans = (ans + (p.m[i][] * s.m[][i]) % m) % m;
  90. }
  91. printf("%d\n", ans % m);
  92. }
  93. return ;
  94. }

[HDOJ2604]Queuing(递推,矩阵快速幂)的更多相关文章

  1. [hdu 2604] Queuing 递推 矩阵快速幂

    Problem Description Queues and Priority Queues are data structures which are known to most computer ...

  2. HDU Queuing(递推+矩阵快速幂)

    Queuing Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  3. hdu 2604 递推 矩阵快速幂

    HDU 2604 Queuing (递推+矩阵快速幂) 这位作者讲的不错,可以看看他的 #include <cstdio> #include <iostream> #inclu ...

  4. HDU 5950 Recursive sequence 【递推+矩阵快速幂】 (2016ACM/ICPC亚洲区沈阳站)

    Recursive sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Other ...

  5. 【递推+矩阵快速幂】【HDU2604】【Queuing】

    Queuing Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  6. HDU 2842 (递推+矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2842 题目大意:棒子上套环.第i个环能拿下的条件是:第i-1个环在棒子上,前i-2个环不在棒子上.每个 ...

  7. Recursive sequence HDU - 5950 (递推 矩阵快速幂优化)

    题目链接 F[1] = a, F[2] = b, F[i] = 2 * F[i-2] + F[i-1] + i ^ 4, (i >= 3) 现在要求F[N] 类似于斐波那契数列的递推式子吧, 但 ...

  8. HDU6030 Happy Necklace(递推+矩阵快速幂)

    传送门:点我 Little Q wants to buy a necklace for his girlfriend. Necklaces are single strings composed of ...

  9. 五校联考R1 Day1T3 平面图planar(递推 矩阵快速幂)

    题目链接 我们可以把棱柱拆成有\(n\)条高的矩形,尝试递推. 在计算的过程中,第\(i\)列(\(i\neq n\))只与\(i-1\)列有关,称\(i-1\)列的上面/下面为左上/左下,第\(i\ ...

  10. LightOJ 1244 - Tiles 猜递推+矩阵快速幂

    http://www.lightoj.com/volume_showproblem.php?problem=1244 题意:给出六种积木,不能旋转,翻转,问填充2XN的格子有几种方法.\(N < ...

随机推荐

  1. [COCI]coci2015/2016 nekameleoni

    题意: 初始数列,每个数都在1~k以内 支持两种操作:1.修改一个数,修改后的数在1~k内                           2.查询一个最短包含1~k的序列的长度 查询100000 ...

  2. Brush Mode --- Nyoj 236 分类: Brush Mode 2014-04-02 06:56 116人阅读 评论(0) 收藏

    心急的C小加 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描述 C小加有一些木棒,它们的长度和质量都已经知道,需要一个机器处理这些木棒,机器开启的时候需要耗费一个单位的时间 ...

  3. 【翻译】Sencha Touch2.4 The Layout System 布局

    [翻译]The Layout System 布局 In Sencha Touch there are two basic building blocks: componentsand containe ...

  4. 已有a,b两个链表,每个链表中的结点包括学号、成绩。要求把两个链表合并,按学号升序排列

    1.我的思路先将b链表连接在a链表的后面,这个很容易实现,将a链表最后的结点中的p.next改为指向b链表的头结点即可. 再将这个新链表用选择排序即可. 代码如下: #include<stdio ...

  5. PowerDesigner(一)-PowerDesigner概述(系统分析与建模)(转)

    PowerDesigner概述 PowerDesigner是Sybase公司推出的一个集成了企业架构,UML(统一建模语言)和数据库的CASE(计算机辅助软件工程)工具.它不仅可以用于系统设计和开发的 ...

  6. 移动MM failed to find resource file{mmiap.xml}

    原地址:http://blog.csdn.net/alking_sun/article/details/36175861 在进行移动MM集成的时候总是会遇到一个bug:  failed to find ...

  7. Java异常类和自定义异常类

    自定义异常类: public class ExtendsException extends Exception { private static final long serialVersionUID ...

  8. POJ 1953

    //FINBONACI数列 #include <iostream> #define MAXN 100 using namespace std; int _m[MAXN]; int main ...

  9. Android中的Context详解

    前言:本文是我读<Android内核剖析>第7章 后形成的读书笔记 ,在此向欲了解Android框架的书籍推荐此书. 大家好,  今天给大家介绍下我们在应用开发中最熟悉而陌生的朋友---- ...

  10. weblogic 安装与配置

    Weblogic 安装 从官网 下载 需要的weblogic 版本, 解压缩后得到 wls1036_generic.jar [fmw_12.1.3.0.0_wls.jar , fmw_12.2.1.1 ...