博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
矩阵快速幂
阅读量:6113 次
发布时间:2019-06-21

本文共 1740 字,大约阅读时间需要 5 分钟。

#include
#include
#include
#include
#include
#include
#include
#include
#define maxint (2147483647)#define l(a) ((a)<<1)#define r(a) ((a)<<1|1)#define b(a) (2<<(a))#define rep(i,a,b) for(int i=a;i<=(b);i++)#define clr(a) memset(a,0,sizeof(a))typedef long long ll;using namespace std;int readint(){ int t=0,f=1;char c=getchar(); while(!isdigit(c)){ if(c=='-') f=-1; c=getchar(); } while(isdigit(c)){ t=(t<<3)+(t<<1)+c-'0'; c=getchar(); } return t*f;}ll readll(){ ll t=0ll,f=1ll;char c=getchar(); while(!isdigit(c)){ if(c=='-') f=-1ll; c=getchar(); } while(isdigit(c)){ t=(t<<3ll)+(t<<1ll)+ll(c-'0'); c=getchar(); } return t*f;}const int maxn=109;const ll mod=1e9+7;int n;ll k;struct matrix{ int a,b; ll x[maxn][maxn]; inline matrix operator*(const matrix A)const{ matrix B;B.clear();B.a=a;B.b=A.b; rep(i,1,a){ rep(j,1,A.b){ rep(k,1,b) B.x[i][j]=(B.x[i][j]+x[i][k]*A.x[k][j])%mod; } } return B; } inline matrix operator^(const ll k)const{ ll t=k;matrix A,B; A.a=B.a=a;A.b=B.b=b; rep(i,1,a) rep(j,1,b) A.x[i][j]=x[i][j]; B.clear(); rep(i,1,a) B.x[i][i]=1; while(t){ if(t&1) B=B*A; A=A*A;t>>=1ll; } return B; } inline void clear(){ rep(i,1,a) rep(j,1,b) x[i][j]=0; } inline void in(int _a,int _b){ a=_a;b=_b; rep(i,1,_a) rep(j,1,_b) x[i][j]=readint(); } inline void out(){ rep(i,1,a){ rep(j,1,b){ printf("%lld",x[i][j]); putchar(j==b?'\n':' '); } } }}X;int main(){ //freopen("#intput.txt","r",stdin); //freopen("#output.txt","w",stdout); n=readint();k=readll();X.in(n,n); matrix Ans=X^k; Ans.out(); //fclose(stdin); //fclose(stdout); return 0;}
View Code

 

转载于:https://www.cnblogs.com/chensiang/p/7754524.html

你可能感兴趣的文章
写给对前途迷茫的朋友:五句话定会改变你的人生
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
JAVA入门到精通-第86讲-半双工/全双工
查看>>
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
[Usaco2015 dec]Max Flow
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>