//Accepted    220 KB    359 ms
 #include <cstdio>
 #include <cstring>
 ;
 int pp;
 struct matrix
 {
     //矩阵m*n
     //(0,0)..(m-1,n-1)
     int a[maxn][maxn];
     int m,n;
     matrix()
     {
         memset(a,,sizeof(a));
         m=n=;
     }
     matrix operator+(matrix mymatrix)
     {
         matrix m_matrix;
         int i,j;
         ;i<m;i++)
         ;j<n;j++)
         m_matrix.a[i][j]=(a[i][j]+mymatrix.a[i][j])%pp;
         m_matrix.m=m;
         m_matrix.n=n;
         return m_matrix;
     }
     matrix operator*(matrix mymatrix)
     {
         matrix m_matrix;
         int i,j,k;
         ;i<m;i++)
         {
             ;j<n;j++)
             {
                 if (a[i][j])
                 ;k<mymatrix.n;k++)
                 m_matrix.a[i][k]=(m_matrix.a[i][k]+a[i][j]*mymatrix.a[j][k])%pp;
             }
         }
         m_matrix.m=m;
         m_matrix.n=mymatrix.n;
         return m_matrix;
     }
     //A^k
     matrix getp(int k)
     {
         matrix d,c;
         ) return *this;
         ) return (*this)*(*this);
         d=getp(k/);
         ==) return d*d;
         else
         return d*d*(*this);
     }
     //A+A^2+A^3+..+A^k
     matrix sump(int k)
     {
         matrix d,c;
         ) return *this;
         ) return (*this)+(*this)*(*this);
         d=sump(k/);
         ==)
         {
             );
         }
         else
         )+getp(k);
     }
     void output()
     {
         int i,j;
         ;i<m;i++)
         {
             ;j<n;j++)
             printf("%d ",a[i][j]%pp);
             printf("\n");
         }
     }
     void input()
     {
         ;i<m;i++)
         {
             ;j<n;j++)
             {
                 scanf("%d",&a[i][j]);
             }
         }
     }
 };
 int n;
 int k;
 matrix tr,mtr;
 int main()
 {
     pp=;
     int T;
     scanf("%d",&T);
     ;t<=T;t++)
     {
         scanf("%d",&n);
         printf("Case %d: ",t);
         )
         {
             ) printf("1\n");
             ) printf("4\n");
             ) printf("9\n");
             continue ;
         }
         tr.m=tr.n=;
         tr.a[][]=;
         tr.a[][]=tr.a[][]=tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr.a[][]=;
         tr=tr.getp(n-);
         mtr.m=;
         mtr.n=;
         mtr.a[][]=;
         mtr.a[][]=;
         mtr.a[][]=;
         mtr.a[][]=;
         tr=mtr*tr;
         printf(][]);
     }
     ;
 }

FZU1683 矩阵的更多相关文章

  1. C语言 · 矩阵乘法 · 算法训练

    问题描述 输入两个矩阵,分别是m*s,s*n大小.输出两个矩阵相乘的结果. 输入格式 第一行,空格隔开的三个正整数m,s,n(均不超过200). 接下来m行,每行s个空格隔开的整数,表示矩阵A(i,j ...

  2. 获取Canvas当前坐标系矩阵

    前言 在我的另一篇博文 Canvas坐标系转换 中,我们知道了所有的平移缩放旋转操作都会影响到画布坐标系.那在我们对画布进行了一系列操作之后,怎么再知道当前矩阵数据状态呢. 具体代码 首先请看下面的一 ...

  3. CSharpGL(32)矩阵与四元数与角度旋转轴的相互转换

    CSharpGL(32)矩阵与四元数与角度旋转轴的相互转换 三维世界里的旋转(rotate),可以用一个3x3的矩阵描述:可以用(旋转角度float+旋转轴vec3)描述.数学家欧拉证明了这两种形式可 ...

  4. “为什么DirectX里表示三维坐标要建一个4*4的矩阵?”

    0x00 前言 首先要说明的是,本文的标题事实上来自于知乎上的一个同名问题:为什么directX里表示三维坐标要建一个4*4的矩阵? - 编程 .因此,正如Milo Yip大神所说的这个标题事实上是存 ...

  5. js实现蛇形矩阵

    参加腾讯前端实习生笔试,真的是被虐了千百遍,除了一条js程序题,其他半点前端都没有,都是考算法,计算机原理,数据结构.下面贴上腾讯笔试最后三大条中的一条,实现一个蛇形矩阵的输出.蛇形矩阵的什么样这里我 ...

  6. ACM 中 矩阵数据的预处理 && 求子矩阵元素和问题

            我们考虑一个$N\times M$的矩阵数据,若要对矩阵中的部分数据进行读取,比如求某个$a\times b$的子矩阵的元素和,通常我们可以想到$O(ab)$的遍历那个子矩阵,对它的各 ...

  7. PAT 1050. 螺旋矩阵(25)

    本题要求将给定的N个正整数按非递增的顺序,填入"螺旋矩阵".所谓"螺旋矩阵",是指从左上角第1个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为m行n列,满足条 ...

  8. [LeetCode] Kth Smallest Element in a Sorted Matrix 有序矩阵中第K小的元素

    Given a n x n matrix where each of the rows and columns are sorted in ascending order, find the kth ...

  9. [LeetCode] Longest Increasing Path in a Matrix 矩阵中的最长递增路径

    Given an integer matrix, find the length of the longest increasing path. From each cell, you can eit ...

随机推荐

  1. 1到N中1出现的次数

    这个问题关键在于好好分析一些样例如: 给定123这个数,你说这个从1到123所有数字中,1出现的次数是多少? 首先我们要分析个位上1出现的次数,我们看看什么情况下个位出现1: 1,11,21,31,4 ...

  2. js上下滚屏效果,代码通过测试

    这是html代码 <div class="box"> <div class="bcon"> <h1><b>领号实 ...

  3. css3内容持续更新ing

    要做在手机里面.4s和5都有差别更加何况还有其他安卓手机,所以做好之后要缩小一点 用的是background.用的了background-size,如果是50%就是等比缩放,50% 50%就会变形,现 ...

  4. edm注意细节

    Email Direct Marketing不要有js,css也放在html里面不能有热区,所有的border要设置为0在浏览器里面邮件发送可能会歪掉,可以测试接受后是否歪掉 有点时候表格会有细缝等等 ...

  5. python中文处理

    源码文件为utf-8格式  CODEC = 'utf-8': VS在“高级保存选项”中选择“UTF-8 65001” input(u'中文');print(u'中文')

  6. 玩转linux文件(重点)

    一.几个主要的操作 mkdir—创建目录 cp—复制文件和目录 mv——移动/重命名文件和目录 rm——删除文件和目录 ln——创建硬链接和软链接 二.几个考点: 通配符 硬链接和软链接(符号链接) ...

  7. CSS3 Media Queries

    Media Queries直译过来就是“媒体查询”,在我们平时的Web页面中head部分常看到这样的一段代码: <link href="css/reset.css" rel= ...

  8. python logger

    [loggers] keys=root [handlers] keys=consoleHandler [formatters] keys=simpleFormatter [logger_root] l ...

  9. 所思所想 js模板引擎

    将服务端生成的HTML标记的事情交给了客户端来做 那么服务端的职责是什么呢? 职责就是处理最终的返回结果,纯数据  handler

  10. 使用Obsolete特性来标记方法过时或弃用

    我们在维护一些老的系统的时候,经常会遇到某个方法不再使用的情况,我们又不能直接将其删除,因为系统中可能还有很多地方有引用它,所以比较安全保险的做法是,使用Obsolete特性来标记它过时或弃用.如下代 ...