微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SpringBoot整合MybatisPlus中矩阵乘法和矩阵的m次幂怎么实现

这篇文章主要介绍SpringBoot整合MybatisPlus中矩阵乘法和矩阵的m次幂怎么实现,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

问题描述

给定一个N阶矩阵A,输出A的M次幂(M是非负整数)
例如:
  A =
  1 2
  3 4
  A的2次幂
  7 10
  15 22

输入格式

第一行是一个正整数N、M(1<=N<=30, 0<=M<=5),表示矩阵A的阶数和要求的幂数
接下来N行,每行N个绝对值不超过10的非负整数,描述矩阵A的值

输出格式

输出共N行,每行N个整数,表示A的M次幂所对应的矩阵。相邻的数之间用一个空格隔开

程序清单

#include <iostream>#include <vector>using namespace std;int N=0,M=0;//函数 MulMatrix()实现矩阵M1*M2 vector<vector <int> > MulMatrix(vector<vector <int> > M1, vector<vector <int> > M2){
   
   
   
	vector<vector <int> > Mul(N, vector<int>(N,0));for(int i=0; i<N; i++)for(int j=0; j<N; j++)for(int k=0; k<N; k++){
   
   
   
				Mul[i][j]+=M1[i][k]*M2[k][j];}return Mul;}//函数ReMulMatrix()实现矩阵A的m次幂 vector <vector <int> > ReMulMatrix(vector <vector <int> > A, int m){
   
   
   
	vector<vector <int> > ResultMatrix(N, vector<int>(N,0));for(int i=0; i<N; i++)  //初始化ResultMatrix为单位矩阵 for(int j=0; j<N; j++){
   
   
   if(i==j)		ResultMatrix[i][j]=1;}if(m==0){
   
   
   return ResultMatrix;  //零次幂为单位矩阵 }else if(m==1)return A;  //1次幂为原矩阵 elsewhile(m!=0){
   
   
   
			ResultMatrix=MulMatrix(ResultMatrix, A);
			m--;}return ResultMatrix;}int main(){
   
   
   
	cin>>N; //N=1-30
	cin>>M; //M=0-5//初始化输入a、输出b为包含N个vector<int>的容器,且每个vector<int>包含N个0 
	vector<vector<int> > Output(N, vector<int>(N,0)), a(N, vector<int>(N,0));//输入 for(int i=0; i<N; i++)for(int j=0; j<N; j++){
   
   
   
			cin>>a[i][j];}  
	//计算 
	Output = ReMulMatrix(a, M);// 输出 for(int i=0; i<N; i++){
   
   
   for(int j=0; j<N; j++){
   
   
   
			cout<<Output[i][j]<<">;} 
		cout<<endl;}return 0;}

测试效果

SpringBoot整合MybatisPlus中矩阵乘法和矩阵的m次幂怎么实现

以上是“SpringBoot整合MybatisPlus中矩阵乘法和矩阵的m次幂怎么实现”这篇文章的所有内容,感谢各位的阅读!希望分享内容对大家有帮助,更多相关知识,欢迎关注编程之家行业资讯频道!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐