洛谷 P3390 【模板】矩阵快速幂
这题的确是个模板
但也要提到有关矩乘的内容:
首先什么是矩阵?
给一个线性变换
F(x) (她可能就是个函数,定义域为向量集)
她可以把一个N维向量变成M维
那么显然x的每一维都可能影响着F(x)的每一维,于是F(x)这个线性变换就应该是N*M个在每两维间的小映射构成的。
于是我们可以把她写成M行N列的矩阵(M行N列是出于习惯)
所以矩阵是用于形象的表示线性变换的工具;
所以怎么合乎习惯的构造矩阵呢?
举例说明:
如,有一个三元组(3维向量)x{a,b,c}
定义F(x)={a+b,b+c}
那么可以构造矩阵(2*3的):
1 1 0
0 1 1
为什么是她呢?
其实矩阵的第i行表示x的每一维对F(x)的第i维的影响;
矩阵的i行j列,表示x的第j维以什么权值(其实是多少倍)影响F(x)第i维的构造;
x的所有维对F(x)的某一维的影响的和,即是F(x)这一维的结果;
如,对于上文中的矩阵;
把x{a,b,c}扔进去;
得到F(x)={1*a+1*b+0*c,0*a+1*b+1*c}={a+b,b+c}
然后什么是矩阵乘法呢?
线性变换作为一种映射,当然可以复合啦!
比如F(x)把五维向量变成四维,G(x)把四维向量变成三维;
那么G[F(x)]就能把五维向量变成三维了;
设H(x)=G[F(x)];
那么H(x)的矩阵是什么呢?
她是G和F的乘积;
如何相乘?
回到本题开头的例子:
F显然是个4*5的矩阵,G是3*4的
H应该是3*5的(行数前列数后)
由上题给出的理解方式H[i,j](表示H的第i行第j列)
表示x的第j维对H(x)的第i行的影响
影响是怎么产生的呢?
Ej先是按照F第j列影响了F(x)的每一维;
F(x)的每一维又按照G第i列影响了G[F(x)]的第i维;
如下图的两矩阵(左边为G,右边F)
*** **
*** **
*** **
***
复合得
**
**
**
**
标记复合矩阵的某点
**
**
**
**
原矩阵的如下点贡献了复合矩阵的这个点
*** **
*** **
*** **
***
所以H[i,j]=F[1,j]*G[i,1]+F[2,j]*G[i,2]+F[3,j]*G[i,3]+....啦
话说,你是可以得知H[i,j]与G,F中的那些值有关,但是你怎么得到具体的公式的呢?
这个公式的证明需要需要用到线性变换的性质——F(x+y)=F(x)+F(y)之类的(还是我之前已经用到了?),
由于篇幅,不好细证,其实举例就能理解的,
(就是这东西很好证,博主我不证啦)
然后是代码:
代码如下:
#include<cstdio>
#include<cstring>
using namespace std;
struct ss{
long long a[][];
};
ss re;
ss map;
ss ans;
int n;
long long m;
ss mul(ss ,ss );
int Sqr(long long ); int main()
{
int i,j,k;
scanf("%d%lld",&n,&m);
for(i=;i<=n;i++){
for(j=;j<=n;j++)
scanf("%d",&map.a[i][j]);
ans.a[i][i]=;
}
Sqr(m);
for(i=;i<=n;i++){
for(j=;j<=n;j++)
printf("%d ",ans.a[i][j]);
printf("\n");
}
return ;
} int Sqr(long long m)
{
while(m){
if(m&)
ans=mul(ans,map);
m>>=;
map=mul(map,map);
}
} ss mul(ss x,ss y){
int i,j,k;
for(i=;i<=n;i++)
for(j=;j<=n;j++){
re.a[i][j]=;
for(k=;k<=n;k++)
re.a[i][j]=(re.a[i][j]+x.a[i][k]*y.a[k][j])% ;
}
return re;
}
祝AC哟;
洛谷 P3390 【模板】矩阵快速幂的更多相关文章
- 【洛谷P3390】矩阵快速幂
矩阵快速幂 题目描述 矩阵乘法: A[n*m]*B[m*k]=C[n*k]; C[i][j]=sum(A[i][1~n]+B[1~n][j]) 为了便于赋值和定义,我们定义一个结构体储存矩阵: str ...
- 3990 [模板]矩阵快速幂 洛谷luogu
题目背景 矩阵快速幂 题目描述 给定n*n的矩阵A,求A^k 输入输出格式 输入格式: 第一行,n,k 第2至n+1行,每行n个数,第i+1行第j个数表示矩阵第i行第j列的元素 输出格式: 输出A^k ...
- ACM-ICPC 2018 焦作赛区网络预赛- L:Poor God Water(BM模板/矩阵快速幂)
God Water likes to eat meat, fish and chocolate very much, but unfortunately, the doctor tells him t ...
- 【洛谷 p3390】模板-矩阵快速幂(数论)
题目:给定n*n的矩阵A,求A^k. 解法:利用矩阵乘法的定义和快速幂解答.注意用负数,但是数据太弱没有卡到我......(P.S.不要在 typedef long long LL; 前使用 LL. ...
- 洛谷 P1965 转圈游戏 —— 快速幂
题目:https://www.luogu.org/problemnew/show/P1965 居然真的就只是 ( x + m * 10k % n ) % n 代码如下: #include<ios ...
- 模板【洛谷P3390】 【模板】矩阵快速幂
P3390 [模板]矩阵快速幂 题目描述 给定n*n的矩阵A,求A^k 矩阵A的大小为n×m,B的大小为n×k,设C=A×B 则\(C_{i,j}=\sum\limits_{k=1}^{n}A_{i, ...
- 【模板】矩阵快速幂 洛谷P2233 [HNOI2002]公交车路线
P2233 [HNOI2002]公交车路线 题目背景 在长沙城新建的环城公路上一共有8个公交站,分别为A.B.C.D.E.F.G.H.公共汽车只能够在相邻的两个公交站之间运行,因此你从某一个公交站到另 ...
- 洛谷P1939【模板】矩阵加速(数列)+矩阵快速幂
思路: 这个 a[1]=a[2]=a[3]=1 a[x]=a[x-3]+a[x-1] (x>3) 可以想成: [a(n) ] [1 0 1] [a(n-1) ] [a(n-1) ] = ...
- 洛谷P3758/BZOJ4887 [TJOI2017] 可乐 [矩阵快速幂]
洛谷传送门,BZOJ传送门 可乐 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 299 Solved: 207 Description 加里敦星球的人 ...
- 洛谷 P1226 【模板】快速幂||取余运算
题目链接 https://www.luogu.org/problemnew/show/P1226 题目描述 输入b,p,k的值,求b^p mod k的值.其中b,p,k*k为长整型数. 输入输出格式 ...
随机推荐
- [java实现]常见算法之字符串操作
一.字符串反转 把一个句子中的打次进行反转,比如“how are you” ,变为 “you are how” // 字符串反转 public class StringTest { // 字符反转的方 ...
- Mysql update from
UPDATE tab1 a INNER JOIN tab_game_version as b ON a.id=b.id SET a.advert_data=0 where a.advert_dat ...
- HTML5 五大特性
一.正则表达式: 相信大家都会非常喜欢这个特性,无须服务器端的检测,使用浏览器的本地功能就可以帮助你判断电子邮件的格式,URL,或者是电话格式,防止用户输入错误的信息,通过使用HTML5的patter ...
- JS DATE对象详解
1.建立时间对象:可获取年,月,日,星期,时,分,秒 var d = new Date(); console.log(d.getFullYear()+'年'+d.getMonth()+'月'+d.ge ...
- java反射机制_读取properties
代码: import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; /** * 反射特点: ...
- 用Akka构建一个简易的分布式文件系统
本来初期打算用Hadoop 2,可是后来有限的服务器部署了Solr Cloud,各种站点,发现资源不够了,近10T的文件,已经几乎把服务器的磁盘全部用光.想来想去,由于目前架构基于Scala的,所以还 ...
- GitBook入门(用github做出第一本书)——超详细配图说明
我最近接触到gitbook,发现它支持markdown和git,刚好把我之前在github上的笔记可以生成一本书,于是我就开始着手捣鼓gitbook,一下午的时间就弄的差不多了,说明这个东西还是挺容易 ...
- Android AES加密工具类实现(基础回顾)
package com.powercreator.cms.util; import java.security.SecureRandom; import javax.crypto.Cipher; im ...
- 微服务Kong(五)——添加一个用户(Consumer)
在本节中,我们将学习如何添加一个用户(consumer)到KONG实例中.用户是与使用您的API的个人相关联,可用于跟踪,访问管理等. NOTE:本节假设您已经正确启用了密钥验证插件.如果没有,请参考 ...
- Wireshark命令行工具tshark详解(含例子)-01
Wireshark命令行工具tshark使用小记 1.目的 写这篇博客的目的主要是为了方便查阅,使用wireshark可以分析数据包,可以通过编辑过滤表达式来达到对数据的分析:但我的需求是,怎么样把D ...