题意:给你矩阵\(A\),求\(S=\sum_{i=1}^{k}A^i\)

构造矩阵

\[\begin{bmatrix}
A & E \\ 0 & E\\
\end{bmatrix}
\]

很酷炫的矩阵套矩阵,学习了

PS.更通用的解法是二分求等比

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<cstdio>
  4. #include<cstring>
  5. #include<cstdlib>
  6. #include<cmath>
  7. #include<string>
  8. #include<vector>
  9. #include<stack>
  10. #include<queue>
  11. #include<set>
  12. #include<map>
  13. #define rep(i,j,k) for(register int i=j;i<=k;i++)
  14. #define rrep(i,j,k) for(register int i=j;i>=k;i--)
  15. #define erep(i,u) for(register int i=head[u];~i;i=nxt[i])
  16. #define iin(a) scanf("%d",&a)
  17. #define lin(a) scanf("%lld",&a)
  18. #define din(a) scanf("%lf",&a)
  19. #define s0(a) scanf("%s",a)
  20. #define s1(a) scanf("%s",a+1)
  21. #define print(a) printf("%lld",(ll)a)
  22. #define enter putchar('\n')
  23. #define blank putchar(' ')
  24. #define println(a) printf("%lld\n",(ll)a)
  25. #define IOS ios::sync_with_stdio(0)
  26. using namespace std;
  27. const int maxn = 1e6+11;
  28. const int oo = 0x3f3f3f3f;
  29. const double eps = 1e-7;
  30. typedef long long ll;
  31. ll read(){
  32. ll x=0,f=1;register char ch=getchar();
  33. while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
  34. while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
  35. return x*f;
  36. }
  37. ll MOD;
  38. inline ll mod(ll a){return a%MOD;}
  39. struct Matrix{
  40. ll mt[77][77],r,c;
  41. void init(int rr,int cc,bool flag=0){
  42. r=rr;c=cc;
  43. memset(mt,0,sizeof mt);
  44. if(flag) rep(i,1,r) mt[i][i]=1;
  45. }
  46. Matrix operator * (const Matrix &rhs)const{
  47. Matrix ans; ans.init(r,rhs.c);
  48. rep(i,1,r){
  49. rep(j,1,rhs.c){
  50. int t=max(r,rhs.c);
  51. rep(k,1,t){
  52. ans.mt[i][j]+=mod(mt[i][k]*rhs.mt[k][j]);
  53. ans.mt[i][j]=mod(ans.mt[i][j]);
  54. }
  55. }
  56. }
  57. return ans;
  58. }
  59. };
  60. Matrix fpw(Matrix A,ll n){
  61. Matrix ans;ans.init(A.r,A.c,1);
  62. while(n){
  63. if(n&1) ans=ans*A;
  64. n>>=1;
  65. A=A*A;
  66. }
  67. return ans;
  68. }
  69. int main(){
  70. ll n,k,m;
  71. while(cin>>n>>k>>m){
  72. MOD=m;
  73. Matrix A; A.init(n,n);
  74. rep(i,1,n)rep(j,1,n) A.mt[i][j]=read();
  75. Matrix UNIT; UNIT.init(n,n,1);
  76. Matrix B; B.init(n<<1,n<<1);
  77. rep(i,1,n)rep(j,1,n) B.mt[i][j]=A.mt[i][j];
  78. rep(i,1,n)rep(j,n+1,n<<1) B.mt[i][j]=UNIT.mt[i][j-n];
  79. rep(i,n+1,n<<1)rep(j,n+1,n<<1) B.mt[i][j]=UNIT.mt[i-n][j-n];
  80. Matrix res=fpw(B,k+1);
  81. rep(i,1,n) rep(j,1,n){
  82. print(mod(res.mt[i][j+n]-(i==j)+m));
  83. if(j<n) blank;
  84. else enter;
  85. }
  86. }
  87. return 0;
  88. }

POJ - 3233 矩阵套矩阵的更多相关文章

  1. C++题解:Matrix Power Series ——矩阵套矩阵的矩阵加速

    Matrix Power Series r时间限制: 1 Sec 内存限制: 512 MB 题目描述 给定矩阵A,求矩阵S=A^1+A^2+--+A^k,输出矩阵,S矩阵中每个元都要模m. 数据范围: ...

  2. POJ3233不错的矩阵(矩阵套矩阵)

    题意:        给一个n*n的矩阵A,然后求S=A + A^2 + A^3 + ..+ A^k. 思路:       矩阵快速幂,这个题目挺新颖的,以往的矩阵快速幂都是退出公式,然后构造矩阵,这 ...

  3. 经典矩阵快速幂之一-----poj3233(矩阵套矩阵

    题意:给你一个矩阵A,求S=A+A^2+A^3+...+A^k. 其实这个当时我看着毫无头绪,看了他们给的矩阵发现好!精!妙! 我们这样看 是不是有点思路! 没错!就是右上角,我们以此类推可以得到A+ ...

  4. Matrix Power Series(POJ 3233 构造新矩阵求解+ 快速矩阵幂)

    题目大意:给定A,k,m(取模),求解S = A + A2 + A3 + … + Ak. 思路:此题为求解幂的和,一开始直接一个个乘,TLE.时间消耗在累加上.此处巧妙构造新矩阵 p=    A 0 ...

  5. Poj 3233 Matrix Power Series(矩阵乘法)

    Matrix Power Series Time Limit: 3000MS Memory Limit: 131072K Description Given a n × n matrix A and ...

  6. POJ 3233 Matrix Power Serie

    题意:给一个n×n的矩阵A,求S = A + A2 + A3 + … + Ak. 解法:从式子中可得递推式S(n) = S(n - 1) + An,An = An-1×A,可得矩阵递推式 [S(n), ...

  7. POJ 3233 Matrix Power Series(矩阵高速功率+二分法)

    职务地址:POJ 3233 题目大意:给定矩阵A,求A + A^2 + A^3 + - + A^k的结果(两个矩阵相加就是相应位置分别相加).输出的数据mod m. k<=10^9.     这 ...

  8. 矩阵儿快速幂 - POJ 3233 矩阵力量系列

    不要管上面的标题的bug 那是幂的意思,不是力量... POJ 3233 Matrix Power Series 描述 Given a n × n matrix A and a positive in ...

  9. 矩阵十点【两】 poj 1575 Tr A poj 3233 Matrix Power Series

    poj 1575  Tr A 主题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1575 题目大意:A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的 ...

随机推荐

  1. 551. Student Attendance Record I 从字符串判断学生考勤

    [抄题]: You are given a string representing an attendance record for a student. The record only contai ...

  2. WCF4.0 –- RESTful WCF Services

    转自:http://blog.csdn.net/fangxinggood/article/details/6235662 WCF 很好的支持了 REST 的开发, 而 RESTful 的服务通常是架构 ...

  3. java容器 Map Set List

    容器:在java中,如果有一个类专门用来存放其他类的对象,这个类就叫做容器,或者叫集合,集合就是将若干性质相同或者相近的类的对象组合在一起而形成一个整体. boolean add(Object obj ...

  4. https抓包

  5. App测试从入门到精通之更新测试

    我们都知道,app在使用一段时间,都会有更新,而且更新会不止一次.在实际测试中,关于更新的测试场景也是我们需要重点关注的,接下来我们就看一下关于App的更新测试有哪些测试点我们需要注意: APP更新测 ...

  6. HDU 4118 Holiday's Accommodation (dfs)

    题意:给n个点,每个点有一个人,有n-1条有权值的边,求所有人不在原来位置所移动的距离的和最大值. 析:对于每边条,我们可以这么考虑,它的左右两边的点数最少的就是要加的数目,因为最好的情况就是左边到右 ...

  7. Struts2 让跳转指定执行某个方法

    很多时候,我们想让jsp页面中的某个超链接,点击后执行后台的某个方法,里面该如何做呢? 这里方法很多种 我举例两种: 1.在struts.xml配置,配置如下: <package name=&q ...

  8. c#缓存介绍

    #缓存介绍(转) 本章导读 缓存主要是为了提高数据的读取速度.因为服务器和应用客户端之间存在着流量的瓶颈,所以读取大容量数据时,使用缓存来直接为客户端服务,可以减少客户端与服务器端的数据交互,从而大大 ...

  9. python DDT读取excel测试数据

    转自:http://www.cnblogs.com/nuonuozhou/p/8645129.html ddt   结合单元测试一起用 ddt(data.driven.test):数据驱动测试 由外部 ...

  10. wpf使用truetype字体ttf

    查了半天都是语焉不详,这篇算是稍微详细点的:http://www.cnblogs.com/junhengml/p/6878933.html 要先查找到字体的字库名称,才能使用: <Window. ...