首先复习快速幂

#include<bits/stdc++.h>
using namespace std;
long long power(long long a,long long b,long long k)
{
long long ans=,base=a;
while (b>)
{
if(b&)
{
ans*=base;
ans%=k;
}
base*=base;
base%=k;
b>>=;
}
return ans;
}
int main()
{
long long b,p,k;
cin>>b>>p>>k;
cout<<b<<'^'<<p<<" mod "<<k<<"="<<(power(b,p,k) % k);
return ;
}

我居然不DEFINE LL?可以看到上面的码十分好懂

那么矩阵快速幂也是一样的 只不过把*换成了mul函数



用计算机模拟矩阵乘法是这样的

struct mat{
long long m[][];//这里不开ll会死人
};
mat mul(mat x,mat y){
mat r;
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
r.m[i][j] = ;
}
}
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
for(int k=;k<=n;k++){
r.m[i][j] += (x.m[i][k] * y.m[k][j]) % p;
r.m[i][j] %= p;
}
}
}
return r;
}

首先定义一个矩阵并赋初值0 然后模拟乘的过程

什么?你想看矩阵乘法的公式?我不会MARKDOWN啊百度麻烦您了

还有一个小问题 就是在矩阵乘法中 什么矩阵是“1"?

答案就是(1,1)(2,2)(3,3).....(N,N)=1 其他地方为0的矩阵(可以自己手动模拟一下)

好了上完整代码

#include<bits/stdc++.h>
#define ll long long
#define p 1000000007 using namespace std; struct mat{
long long m[][];
}e,ans1,ans2; ll k,n; mat mul(mat x,mat y){
mat r;
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
r.m[i][j] = ;
}
}
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
for(int k=;k<=n;k++){
r.m[i][j] += (x.m[i][k] * y.m[k][j]) % p;
r.m[i][j] %= p;
}
}
}
return r;
} mat pow(mat x,ll y){
mat ans = e;
while (y>){
if(y&){
ans = mul(ans,x);
}
x=mul(x,x);
y>>=;
}
return ans;
} int main(){
cin>>n>>k;
for(int i=;i<=n;i++) e.m[i][i] = ;
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
scanf("%d",&ans1.m[i][j]);
}
}
ans2 =pow (ans1,k);
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
printf("%d ",ans2.m[i][j]);
}
cout<<endl;
}
return ;
}

你会了这个才会矩阵加速之类乱七八糟的东西

TAG:SIN_XIII ⑨

【数论】 快速幂&&矩阵快速幂的更多相关文章

  1. 矩阵乘法&矩阵快速幂&矩阵快速幂解决线性递推式

    矩阵乘法,顾名思义矩阵与矩阵相乘, 两矩阵可相乘的前提:第一个矩阵的行与第二个矩阵的列相等 相乘原则: a b     *     A B   =   a*A+b*C  a*c+b*D c d     ...

  2. 快速幂 & 矩阵快速幂

    目录 快速幂 实数快速幂 矩阵快速幂 快速幂 实数快速幂 普通求幂的方法为 O(n) .在一些要求比较严格的题目上很有可能会超时.所以下面来介绍一下快速幂. 快速幂的思想其实是将数分解,即a^b可以分 ...

  3. jiulianhuan 快速幂--矩阵快速幂

    题目信息: 1471: Jiulianhuan 时间限制: 1 Sec  内存限制: 128 MB 提交: 95  解决: 22 题目描述 For each data set in the input ...

  4. 整数快速乘法/快速幂+矩阵快速幂+Strassen算法

    快速幂算法可以说是ACM一类竞赛中必不可少,并且也是非常基础的一类算法,鉴于我一直学的比较零散,所以今天用这个帖子总结一下 快速乘法通常有两类应用:一.整数的运算,计算(a*b) mod c  二.矩 ...

  5. 快速幂&&矩阵快速幂

    快速幂 题目链接:https://www.luogu.org/problemnew/show/P1226 快速幂用了二分的思想,即将\(a^{b}\)的指数b不断分解成二进制的形式,然后相乘累加起来, ...

  6. [板子]快速幂&矩阵快速幂

    不会的来这看:https://www.cnblogs.com/CXCXCXC/p/4641812.html 简单的一说:当转换为二进制的时候有位运算这种黑科技,&相当于%2判断奇偶性. x&a ...

  7. hdu 4549 M斐波那契数列(快速幂 矩阵快速幂 费马小定理)

    题目链接http://acm.hdu.edu.cn/showproblem.php?pid=4549: 题目是中文的很容易理解吧.可一开始我把题目看错了,这毛病哈哈. 一开始我看错题时,就用了一个快速 ...

  8. 矩阵快速幂模板(pascal)

    洛谷P3390 题目背景 矩阵快速幂 题目描述 给定n*n的矩阵A,求A^k 输入输出格式 输入格式: 第一行,n,k 第2至n+1行,每行n个数,第i+1行第j个数表示矩阵第i行第j列的元素 输出格 ...

  9. 培训补坑(day10:双指针扫描+矩阵快速幂)

    这是一个神奇的课题,其实我觉得用一个词来形容这个算法挺合适的:暴力. 是啊,就是循环+暴力.没什么难的... 先来看一道裸题. 那么对于这道题,显然我们的暴力算法就是枚举区间的左右端点,然后通过前缀和 ...

随机推荐

  1. Java多线程编程的常见陷阱

    .在构造函数中启动线程 我在很多代码中都看到这样的问题,在构造函数中启动一个线程,类似这样: public class A{ public A(){ ; ; this.thread=new MyThr ...

  2. 深度学习网络中numpy多维数组的说明

    目前在计算机视觉中应用的数组维度最多有四维,可以表示为 (Batch_size, Row, Column, Channel) 以下将要从二维数组到四维数组进行代码的简单说明: Tips: 1) 在nu ...

  3. 开箱即用的VScode C++环境

    对大部分人来说vscode配置c++环境十分繁琐,这里提供简单方法. 1. 下载VSCode 官方网站下载(便携版):VSCode-win32-ia32-1.32.1.zip 解压VSCode-win ...

  4. Spark机器学习基础三

    监督学习 0.线性回归(加L1.L2正则化) from __future__ import print_function from pyspark.ml.regression import Linea ...

  5. java基础之集合框架--使用ArrayList类动态 存储数据

    一.ArrayList是List接口下的一个实现类,实现了长度可变的.连续的数组:拥有数组的特性. 遵循了LIst的规则:不唯一的.有序的. 如果没有增加泛型的话,集合中可以添加任何类型的数据. 使用 ...

  6. CentOS7攻克日记(四) —— 安装Mysql和Redis

    这一篇主要安装mysql,redis等数据库   在这篇开始之前,有一个坑,上一篇更改python软连接的时候,尽量都用名字是python3来软连接/usr/../bin/python3.6,把名字是 ...

  7. ios高级开发之多线程(三)GCD技术

    GCD是基于C的API,它是libdispatch的的市场名称.而libdispatch作为Apple公司的一个库,为并发代码在多核硬件(跑IOS或者OS X)上执行提供有力支持. 那么我们为什么要用 ...

  8. ios高级开发之多线程(一)

    1.概念: 多线程(multithreading)到底是什么呢,它是指在软件或者硬件上实现多个线程并发执行的技术.具有多线程能力的计算机因有硬件的支持,而能够在同一时间执行多个线程,进而提升整体处理性 ...

  9. java的hello world

    public class HelloWorld { public static void main(String []args) { System.out.println("Hello Wo ...

  10. 【笔记】Nginx热更新相关知识

    (以下学习笔记内容均摘自参考链接,仅供个人查阅)   1.inotify文件系统监控特性 Inotify 是一个 Linux 内核特性,它监控文件系统,并且及时向专门的应用程序发出相关的事件警告,比如 ...