题意:

给出一个\(n \times n\)的矩阵\(A\),求\(A+A^2+A^3+ \cdots + A^k\)。

分析:

这题是有\(k=0\)的情况,我们一开始先特判一下,直接输出单位矩阵\(E\)。

下面讨论\(k > 0\)的情况:

方法一

设答案为\(S_k(k > 0)\)

把矩阵增广一下

$\begin{bmatrix}

A & O \

E & E

\end{bmatrix}

\begin{bmatrix}

A^n\

S_{n-1}

\end{bmatrix}

\begin{bmatrix}

A^{n+1}\

S_n

\end{bmatrix}\(
\)E\(表示单位矩阵,\)O\(是全为零的矩阵。
\){\begin{bmatrix}

A & O \

E & E

\end{bmatrix}}^k

\begin{bmatrix}

A\

O

\end{bmatrix}

\begin{bmatrix}

A^{k+1}\

S_k

\end{bmatrix}$

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. using namespace std;
  5. const int maxn = 40;
  6. const int MOD = 10;
  7. int mul(int a, int b) { return a * b % MOD; }
  8. void add(int& a, int b) { a += b; if(a >= MOD) a -= MOD; }
  9. int n, k, sz;
  10. int a[maxn][maxn], b[maxn][maxn];
  11. struct Matrix
  12. {
  13. int a[maxn * 2][maxn * 2];
  14. Matrix() { memset(a, 0, sizeof(a)); }
  15. Matrix operator * (const Matrix& t) const {
  16. Matrix ans;
  17. for(int i = 0; i < sz; i++)
  18. for(int j = 0; j < sz; j++)
  19. for(int k = 0; k < sz; k++)
  20. add(ans.a[i][j], mul(a[i][k], t.a[k][j]));
  21. return ans;
  22. }
  23. void output() {
  24. for(int i = 0; i < sz; i++) {
  25. for(int j = 0; j < sz - 1; j++)
  26. printf("%d ", a[i][j]);
  27. printf("%d\n", a[i][sz - 1]);
  28. }
  29. printf("\n");
  30. }
  31. };
  32. Matrix pow_mod(Matrix a, int p) {
  33. Matrix ans;
  34. for(int i = 0; i < sz; i++) ans.a[i][i] = 1;
  35. while(p) {
  36. if(p & 1) ans = ans * a;
  37. a = a * a;
  38. p >>= 1;
  39. }
  40. return ans;
  41. }
  42. int main()
  43. {
  44. while(scanf("%d%d", &n, &k) == 2 && n) {
  45. Matrix M;
  46. for(int i = 0; i < n; i++)
  47. for(int j = 0; j < n; j++) {
  48. scanf("%d", &a[i][j]);
  49. a[i][j] %= MOD;
  50. M.a[i][j] = a[i][j];
  51. }
  52. if(!k) {
  53. for(int i = 0; i < n; i++) {
  54. for(int j = 0; j < n - 1; j++)
  55. printf("%d ", i == j ? 1 : 0);
  56. printf("%d\n", i == n - 1 ? 1 : 0);
  57. }
  58. printf("\n");
  59. continue;
  60. }
  61. for(int i = n; i < n * 2; i++)
  62. M.a[i][i] = M.a[i][i - n] = 1;
  63. sz = n * 2;
  64. M = pow_mod(M, k);
  65. memset(b, 0, sizeof(b));
  66. for(int i = 0; i < n; i++)
  67. for(int j = 0; j < n; j++) if(M.a[i + n][j])
  68. for(int k = 0; k < n; k++)
  69. add(b[i][k], mul(M.a[i + n][j], a[j][k]));
  70. for(int i = 0; i < n; i++) {
  71. for(int j = 0; j < n - 1; j++)
  72. printf("%d ", b[i][j]);
  73. printf("%d\n", b[i][n - 1]);
  74. }
  75. printf("\n");
  76. }
  77. return 0;
  78. }

方法二

有如下递归式:

  • \(S_k=(E+A^{\frac{k}{2}})S^{\frac{k}{2}}\),k是偶数
  • \(S_k=(E+A^{\frac{k}{2}})S^{\frac{k}{2}}+A^k\),k是奇数

所以也可以直接递归求解。

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. using namespace std;
  5. const int maxn = 40;
  6. const int MOD = 10;
  7. int mul(int a, int b) { return a * b % MOD; }
  8. void add(int& a, int b) { a += b; if(a >= MOD) a -= MOD; }
  9. int n, k;
  10. struct Matrix
  11. {
  12. int a[maxn][maxn];
  13. Matrix() { memset(a, 0, sizeof(a)); }
  14. void E() {
  15. memset(a, 0, sizeof(a));
  16. for(int i = 0; i < maxn; i++) a[i][i] = 1;
  17. }
  18. Matrix operator + (const Matrix& t) const {
  19. Matrix ans;
  20. for(int i = 0; i < n; i++)
  21. for(int j = 0; j < n; j++) {
  22. add(ans.a[i][j], a[i][j]);
  23. add(ans.a[i][j], t.a[i][j]);
  24. }
  25. return ans;
  26. }
  27. Matrix operator * (const Matrix& t) const {
  28. Matrix ans;
  29. for(int i = 0; i < n; i++)
  30. for(int j = 0; j < n; j++) if(a[i][j])
  31. for(int k = 0; k < n; k++)
  32. add(ans.a[i][k], mul(a[i][j], t.a[j][k]));
  33. return ans;
  34. }
  35. void output() {
  36. for(int i = 0; i < n; i++) {
  37. for(int j = 0; j < n - 1; j++)
  38. printf("%d ", a[i][j]);
  39. printf("%d\n", a[i][n - 1]);
  40. }
  41. printf("\n");
  42. }
  43. };
  44. Matrix pow_mod(Matrix a, int p) {
  45. Matrix ans;
  46. ans.E();
  47. while(p) {
  48. if(p & 1) ans = ans * a;
  49. a = a * a;
  50. p >>= 1;
  51. }
  52. return ans;
  53. }
  54. Matrix E;
  55. Matrix sum(Matrix a, int p) {
  56. if(p == 1) return a;
  57. Matrix ans;
  58. ans = (E + pow_mod(a, p / 2)) * sum(a, p / 2);
  59. if(p & 1) ans = ans + pow_mod(a, p);
  60. return ans;
  61. }
  62. int main()
  63. {
  64. E.E();
  65. while(scanf("%d%d", &n, &k) == 2) {
  66. if(n == 0 && k == 0) break;
  67. Matrix a;
  68. for(int i = 0; i < n; i++)
  69. for(int j = 0; j < n; j++) {
  70. scanf("%d", &a.a[i][j]);
  71. a.a[i][j] %= 10;
  72. }
  73. if(k == 0) {
  74. E.output();
  75. continue;
  76. }
  77. a = sum(a, k);
  78. a.output();
  79. }
  80. return 0;
  81. }

UVa 11149 Power of Matrix 矩阵快速幂的更多相关文章

  1. UVa 11149 Power of Matrix (矩阵快速幂,倍增法或构造矩阵)

    题意:求A + A^2 + A^3 + ... + A^m. 析:主要是两种方式,第一种是倍增法,把A + A^2 + A^3 + ... + A^m,拆成两部分,一部分是(E + A^(m/2))( ...

  2. UVA 11149 - Power of Matrix(矩阵乘法)

    UVA 11149 - Power of Matrix 题目链接 题意:给定一个n*n的矩阵A和k,求∑kiAi 思路:利用倍增去搞.∑kiAi=(1+Ak/2)∑k/2iAi,不断二分就可以 代码: ...

  3. UVA 11149.Power of Matrix-矩阵快速幂倍增

    Power of Matrix UVA - 11149       代码: #include <cstdio> #include <cstring> #include < ...

  4. POJ 3233 Matrix Power Series(矩阵快速幂)

    Matrix Power Series Time Limit: 3000MS Memory Limit: 131072K Total Submissions: 19338 Accepted: 8161 ...

  5. POJ 3233 Matrix Power Series (矩阵快速幂+二分求解)

    题意:求S=(A+A^2+A^3+...+A^k)%m的和 方法一:二分求解S=A+A^2+...+A^k若k为奇数:S=(A+A^2+...+A^(k/2))+A^(k/2)*(A+A^2+...+ ...

  6. POJ 3233 Matrix Power Series (矩阵快速幂)

    题目链接 Description Given a n × n matrix A and a positive integer k, find the sum S = A + A^2 + A^3 + - ...

  7. 题解报告:poj 3233 Matrix Power Series(矩阵快速幂)

    题目链接:http://poj.org/problem?id=3233 Description Given a n × n matrix A and a positive integer k, fin ...

  8. poj3233 Matrix Power Series(矩阵快速幂)

    题目要求的是 A+A2+...+Ak,而不是单个矩阵的幂. 那么可以构造一个分块的辅助矩阵 S,其中 A 为原矩阵,E 为单位矩阵,O 为0矩阵    将 S 取幂,会发现一个特性: Sk +1右上角 ...

  9. fzu 1911 Construct a Matrix(矩阵快速幂+规律)

    题目链接:fzu 1911 Construct a Matrix 题目大意:给出n和m,f[i]为斐波那契数列,s[i]为斐波那契数列前i项的和.r = s[n] % m.构造一个r * r的矩阵,只 ...

随机推荐

  1. 下一代的前端构建工具:parcel打包react

    1. parcel很受欢迎,webpack太慢了,试试Parcel下一代的前端构建工具 2.Parcel很快,但缺少好多插件,没有base64,没有办法拆分打包文件.... 3.总结:适合小项目 4. ...

  2. MyBatis配置文件之properties属性

    MyBatis提供3个方式使用properties: 1.property子元素. 2.properties文件. 3.程序代码传递. properties属性系给系统配置一些运行参数,一般放在XML ...

  3. ImageLoader常用方法注释

    ImageLoader中的常用方法及相关作用注释 ImageLoader 的ImageLoaderConfiguration config 配置 ImageLoaderConfiguration co ...

  4. 【虚拟机-网络IP】使用 Powershell 设置 VNET 中的静态 IP

    本文包含以下内容 对已有虚机设置静态 Internal IP 取消对对已有虚机设置的静态 Internal IP 创建静态 Internal IP的虚机 使用中的注意点 请注意:以下操作需要下载最新版 ...

  5. NVM for Windows下载与安装

    下载NVM for Windows https://github.com/coreybutler/nvm-windows/releases nvm-noinstall.zip: 这个是绿色免安装版本, ...

  6. ThinkPHP笔记——开启debug调试模式

    debug+trace模式可以查看开发过程中TP的错误信息,可以更好地帮助开发者debug.但是debug模式的开启还不是简单的在配置文件中中设置就可以的,经过查资料摸索,找到一种有效的方法. 首先在 ...

  7. Codeforces Round #313 (Div. 2) A.B,C,D,E Currency System in Geraldion Gerald is into Art Gerald's Hexagon Equivalent Strings

    A题,超级大水题,根据有没有1输出-1和1就行了.我沙茶,把%d写成了%n. B题,也水,两个矩形的长和宽分别加一下,剩下的两个取大的那个,看看是否框得下. C题,其实也很简单,题目保证了小三角形是正 ...

  8. python 基础之while无限循环

    用户登录程序 username = "chenxi" passwed = "testki" counter = 0 while counter < 3: ...

  9. PropertyConfigurer.java

    package util; import java.util.Properties; import org.springframework.beans.BeansException; import o ...

  10. springboot 内置tomcat maxPostSizs 无法设置

    ++++++++++++++++++ RT +++++++++++++++++ 如下代码方可解决: /** * tomcat配置类 * 解决post数据体大于2048kb无法接收问题 * 解决tomc ...