Tr A

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4549    Accepted Submission(s): 3428

Problem Description
A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的和),现要求Tr(A^k)%9973。
Input
数据的第一行是一个T,表示有T组数据。
每组数据的第一行有n(2 <= n <= 10)和k(2 <= k < 10^9)两个数据。接下来有n行,每行有n个数据,每个数据的范围是[0,9],表示方阵A的内容。
Output
对应每组数据,输出Tr(A^k)%9973。
Sample Input
2 2 2 1 0 0 1 3 99999999 1 2 3 4 5 6 7 8 9
Sample Output
2 2686
矩阵快速幂 求模
代码:

#include <iostream>
#include<cstdio>
#include<cstring>
#define mod 9973
using namespace std;
struct Matrix
{int A[20][20];int r,c;//矩阵行列,这一题行列均为n
};
Matrix ori,res;
int n;
void Init(int n)
{memset(res.A,0,sizeof(res.A));//矩阵初始化for(int i=0;i<n;i++){res.A[i][i]=1;for(int j=0;j<n;j++){scanf("%d",&ori.A[i][j]);}}
}
//矩阵乘法
Matrix multiple(Matrix a,Matrix b)
{Matrix c;memset(c.A,0,sizeof(c.A));for(int i=0;i<n;i++){for(int k=0;k<n;k++){if(a.A[i][k]==0) continue;for(int j=0;j<n;j++){c.A[i][j]=(c.A[i][j]+(a.A[i][k]*b.A[k][j])%mod)%mod;}}}return c;//返回”矩阵“结构体
}
//矩阵快速幂
void Matrix_mod(Matrix ori,int k)
{while(k){if(k&1)res=multiple(ori,res);ori=multiple(ori,ori);k>>=1;}int  ans=0;for(int i=0;i<n;i++){ans=(ans+res.A[i][i])%mod;}printf("%d\n",ans);
}
int main()
{int t,k;scanf("%d",&t);while(t--){scanf("%d%d",&n,&k);Init(n);Matrix_mod(ori,k);}return 0;
}

第一道矩阵快速幂,和普通快速幂差不多,只不过这里是矩阵的运算和取模。

转自:点击打开链接
转载一个写的可好的详解:

基础知识:(会基础的直接看应用部分)

(1)矩阵乘法

简单的说矩阵就是二维数组,数存在里面,矩阵乘法的规则:A*B=C


其中c[i][j]为A的第i行与B的第j列对应乘积的和,即:

代码:

[cpp] view plaincopy
  1. const int N=100;
  2. int c[N][N];
  3. void multi(int a[][N],int b[][N],int n)
  4. {
  5. memset(c,0,sizeof c);
  6. for(int i=1;i<=n;i++)
  7. for(int j=1;j<=n;j++)
  8. for(int k=1;k<=n;k++)
  9. c[i][j]+=a[i][k]*b[k][j];
  10. }

另一种写法:

[cpp] view plaincopy
  1. int c[N][N];
  2. void multi(int a[][N],int b[][N],int n)
  3. {
  4. memset(c,0,sizeof c);
  5. for(int i=1;i<=n;i++)
  6. for(int k=1;k<=n;k++)
  7. for(int j=1;j<=n;j++)
  8. c[i][j]+=a[i][k]*b[k][j];
  9. }

这种可以在第二重for判断if(a[i][k]==0)continue;对于矩阵有较多0的有一定效果。不过一般第一种写法就够了,这种知道就行。

显然矩阵乘法的复杂度是O(n^3);(O(n^2.7)的方法不会写,无视这里)。

这里我直接写的是n*n的矩阵(即方阵),显然两个相乘是要一行和一列对应乘,那么矩阵乘法是需要A的行数与B的列数相等的(这是A*B的前提条件,可见矩阵的乘法是不满足交换律的)。然而这些一般都是没什么用的,矩阵快速幂只会用到方阵(除非题目是裸的矩阵乘法)。矩阵快速幂都是方阵也就避免的相乘的前提条件,可以放心用。

(1)矩阵快速幂

就是算A^n;方法很简单,把快速幂算法中的乘法改成矩阵的乘法就可以了

代码:

[cpp] view plaincopy
  1. const int N=10;
  2. int tmp[N][N];
  3. void multi(int a[][N],int b[][N],int n)
  4. {
  5. memset(tmp,0,sizeof tmp);
  6. for(int i=1;i<=n;i++)
  7. for(int j=1;j<=n;j++)
  8. for(int k=1;k<=n;k++)
  9. tmp[i][j]+=a[i][k]*b[k][j];
  10. for(int i=1;i<=n;i++)
  11. for(int j=1;j<=n;j++)
  12. a[i][j]=tmp[i][j];
  13. }
  14. int res[N][N];
  15. void Pow(int a[][N],int n)
  16. {
  17. memset(res,0,sizeof res);
  18. for(int i=1;i<=n;i++) res[i][i]=1;
  19. while(n)
  20. {
  21. if(n&1)
  22. multi(res,a,n);//res=res*a;复制直接在multi里面实现了;
  23. multi(a,a,n);//a=a*a
  24. n>>=1;
  25. }
  26. }

这代码看看就好,我的写法一般人不是很喜欢看,网上有很多种写法,比如用结构体存矩阵什么的,模板建议还是自己写的好,自己怎么写顺溜就怎么写呗,弄清楚原理就好。

不过上诉res数组就等同于普通快速幂初始化的1,原理想通的,这个矩阵叫单位矩阵E,性质就是E*A=A,就是1*a=a,一样,单位矩阵就是对角线全是1其他全是0;

最终算出的结果是一个res矩阵,具体有什么用就看下面的应用。

应用篇

主要通过把数放到矩阵的不同位置,然后把普通递推式变成"矩阵的等比数列",最后快速幂求解递推式:

先通过入门的题目来讲应用矩阵快速幂的套路(会这题的也可以看一下套路):

例一:http://poj.org/problem?id=3070
题目:斐波那契数列f(n),给一个n,求f(n)%10000,n<=1e9;

(这题是可以用fibo的循环节去做的,不过这里不讲,反正是水题)

矩阵快速幂是用来求解递推式的,所以第一步先要列出递推式:

 f(n)=f(n-1)+f(n-2)

第二步是建立矩阵递推式,找到转移矩阵:

,简写成T * A(n-1)=A(n),T矩阵就是那个2*2的常数矩阵,而

这里就是个矩阵乘法等式左边:1*f(n-1)+1*f(n-2)=f(n);1*f(n-1)+0*f(n-2)=f(n-1);

这里还是说一下构建矩阵递推的大致套路,一般An与A(n-1)都是按照原始递推式来构建的,当然可以先猜一个An,主要是利用矩阵乘法凑出矩阵T,第一行一般就是递推式,后面的行就是不需要的项就让与其的相乘系数为0。矩阵T就叫做转移矩阵(一定要是常数矩阵),它能把A(n-1)转移到A(n);然后这就是个等比数列,直接写出通项:此处A1叫初始矩阵。所以用一下矩阵快速幂然后乘上初始矩阵就能得到An,这里An就两个元素(两个位置),根据自己设置的A(n)对应位置就是对应的值,按照上面矩阵快速幂写法,res[1][1]=f(n)就是我们要求的。

给一些简单的递推式
1.f(n)=a*f(n-1)+b*f(n-2)+c;(a,b,c是常数)

2.f(n)=c^n-f(n-1) ;(c是常数)

继续例题二:poj3233

Description

Given a n × n matrix A and a positive integer k, find the sum S = A + A2 + A3 + … + Ak.

Input

The input contains exactly one test case. The first line of input contains three positive integers n (n ≤ 30), k (k ≤ 109) and m (m < 104). Then follow n lines each containing n nonnegative integers below 32,768, giving A’s elements in row-major order.

Output

Output the elements of S modulo m in the same way as A is given

这题就是求一个矩阵的和式:S(k),直接对和式建立递推:


建立矩阵,注意此处S和A都是2*2的矩阵,E表示单位矩阵,O表示零矩阵(全是0,与其他矩阵相乘都为0),显然E,O都是2*2的

这里转移矩阵是4*4.OVER


一般这种题目都是要找递推式,这是难点.

例三:HDU2276

题意就是说n个灯排成环i号灯的左边是i-1号,1的左边是n号,给定初始灯的开闭状态(用1,0表示),然后每一秒都操作都是对于每个灯i,如果它左边的灯是开的就把i状态反转(0变1,1变0),问m秒都最终状态是什么,m<=1e8,n<=100;

这题的递推式没有明说,但是每一秒操作一次其实就是一次递推,那么关键就是要找转移矩阵,而且比较是常数矩阵,这个才能用等比的性质

我们把n个灯的状态看出一个F(n),其实就是一个n*1的01矩阵,然后考虑从上一秒的状态F(n-1)如何转移到F(n)。既然每个状态都要转移,总共n个状态,可以看出转移矩阵就是一个n*n的矩阵(每一个灯的状态都用一个1*n的矩阵来转移)

先考虑第一个灯:影响它新状态的只有它左右的灯和它自己的状态,仔细想一下,1*n的转移中只有这两位置有用,那么其他都是0,就这样

这里state2到staten-1都被0干掉了,只有第一个和1号左边的灯有效

(这里不具体讲了,只有0,1的状态,自己枚举一下state1和state2,矩阵相乘后都是能正确转移的)

其他灯的考虑都是一样的,最终:

OVER

例四:HDU 5015
题意就是一个矩阵a,第一行依次是0,233,2333,23333......,给出矩阵的递推式:a[i][j]=a[i-1][j]+a[i][j-1],输入的是第零列,求a[n][m],n ≤ 10,m ≤ 109
解:n很小,m很大,m大概就是作为幂次,以每一列为一个矩阵A(n-1)并且向下一列A(n)转移,那么关键就是找转移矩阵了:
先看第一行的数233后面每次都添一个3,显然递推关系就是A(n-1)*10+3=A(n),这里多一个3,必须把列数新增一个元素3,也就是一个(n+1)*1的矩阵A(n).
然后其他的元素转移会出现一个问题,a[i][j]=a[i-1][j]+a[i][j-1];这里a[i-1][j]依旧是新一列的元素,这是不能矩阵转移的,因为矩阵转移必须从旧的矩阵状态A(n-1)变到新状态A(n)。
那么这里a[i-1][j]就用递归思想,沿用上一行的转移矩阵(上一行能转移出a[i-1][j]),再加上新增的转移:

OVER

当然矩阵还有很多奇葩的递推,比如这矩阵优化的dp题。

推荐一些题目:

简单的:

http://acm.hdu.edu.cn/showproblem.php?pid=1757

http://acm.hdu.edu.cn/showproblem.php?pid=1575

不简单的:

http://acm.hdu.edu.cn/showproblem.php?pid=3483

http://acm.hdu.edu.cn/showproblem.php?pid=2855

http://acm.hdu.edu.cn/showproblem.php?pid=3658

http://acm.hdu.edu.cn/showproblem.php?pid=4565

hdoj 1575 Tr A (矩阵快速幂)相关推荐

  1. HDU (1575)Tr A ---矩阵快速幂

    Tr A Problem Description A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的和),现要求Tr(A^k)%9973. Input 数据的第一行是一个T,表示有T组数据. 每 ...

  2. Tr A 矩阵快速幂

    A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的和),现要求Tr(A^k)%9973. Input 数据的第一行是一个T,表示有T组数据. 每组数据的第一行有n(2 <= n <= ...

  3. Tr A(矩阵快速幂)

    A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的和),现要求Tr(A^k)%9973. Input 数据的第一行是一个T,表示有T组数据.  每组数据的第一行有n(2 <= n < ...

  4. 40行代码AC_HDU 1575 TrA 矩阵快速幂(附快速幂+矩阵快速幂的讲解)

    一道经典的矩阵快速幂模板题. 传送门1-->快速幂基本思想 传送门2-->矩阵快速幂讲解(教主传授) 心路历程 1.开始看成求主对角线元素和的n次幂了,用快速幂解得.结果压根不对,又仔细看 ...

  5. HDOJ 1757 A Simple Math Problem(矩阵快速幂)

    2018-5-24 简单的矩阵快速幂问题,重点是如何找到对应关系. f(10) a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 f(9) f(9) 1 0 0 0 0 0 0 0 0 0 ...

  6. HDOJ 2604 Queuing (递推+矩阵快速幂)

    点击打开链接 题意:给你一个长度为L的由m和f两种字母组成的字符串,定义存在fmf以及fff子串的都是不符合要求的串,问长度为L的符合要求的串有多少个? 解题思路: 首先找出递推关系式,先给出递推关系 ...

  7. 矩阵快速幂的学习(系统的学习)

    学习博客:https://www.cnblogs.com/cmmdc/p/6936196.html https://www.cnblogs.com/yan-boy/archive/2012/11/29 ...

  8. 2020.7.20【算协集训】矩阵快速幂

    算法分析与排序 A - Fibonacci (POJ - 3070) 分析 代码 B - Tr A (HDU - 1575) 分析 代码 C - A Simple Math Problem (HDU ...

  9. 2021-2022年度第三届全国大学生算法设计与编程挑战赛(秋季赛)- 分组(矩阵快速幂套NTT优化dp)

    题目链接:点击查看 题目大意:给出 nnn 个连续的小球,每次可以选择单独的一个或者相邻的两个小球分成一组,允许有剩余的小球,问恰好分成 k∈{1,2,3,⋯,m}k\in\{1,2,3,\cdots ...

  10. 2021HDU多校8 - 7057 Buying Snacks(矩阵快速幂套NTT优化dp)

    题目链接:点击查看 题目大意:给出 nnn 种糖果,每种糖果有大小包装之分,有三种购买方案,价钱分别如下: 单独购买一个小的,花费一块钱 单独购买一个大的,花费两块钱 ∀i>1\forall i ...

最新文章

  1. 猫猫学iOS 之第一次打开Xcode_git配置,git简单学习
  2. Ant Design Pro+Electron+electron-builder实现React应用脱离浏览器,桌面安装运行
  3. 设置Qt应用程序图标
  4. mysql数据库ip地址_MySQL数据库存储IP地址的方法
  5. 《C++ Primer 第五版》(第6.3~6.7节)——返回指向数组/函数的指针,函数重载,默认形参、inline函数和constexpr函数
  6. 第九节:委托和事件(1)(委托的发展历史、插件式编程、多播委托)
  7. 每个大数据工程师都应该知道的OLAP 核心知识点
  8. python虚拟环境安装包在哪_ubuntu环境下python虚拟环境的安装
  9. ABB机器人编程软件RobotStudio迅雷下载网盘下载
  10. VMware虚拟机的下载与安装(附Win10简易安装教程)
  11. 【计算机组成原理】中央处理器(三)—— 数据通路
  12. 软件开发模式介绍和对比(瀑布、迭代、敏捷等)
  13. 双三次插值 python实现_双三次插值Python
  14. 食饵捕食者模matlab,食饵——捕食者数学模型研究.doc
  15. 员工转正申请书_简短的员工转正申请书范文6篇
  16. 网站被流量攻击怎么处理
  17. html设置表单里面字体格式为中文,html设置字体样式 html怎么设置字体样式 html字体怎么设置...
  18. 最接地气的Android面试总结心得
  19. JAVA程序员面试至尊宝典
  20. 搜狗浏览器如何下载安装 安装搜狗浏览器的详细步骤

热门文章

  1. 玩转代码|简单分析如何获取小程序的t值
  2. 线性回归实现人脸识别——ORL数据集
  3. html修改鼠标手势,css要怎么设置鼠标手势?
  4. Redis 下载与安装(Windows版)
  5. 2020、2021年FRM一级二级notes
  6. 摩尔庄园不同服务器账号互通吗,摩尔庄园手游服务器互通吗?摩尔庄园手游不同区可以一起玩吗?...
  7. 摩尔定律和梅特卡夫定律_摩尔定律f
  8. 整理了100个必备的 Python 函数,值得收藏
  9. Failed installing 'Tomcat9' service
  10. 傅里叶分析原理——非常好的一篇讲解文章