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

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

创新互联公司专注于企业成都全网营销推广、网站重做改版、湘西土家族网站定制设计、自适应品牌网站建设、HTML5商城建设、集团公司官网建设、外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为湘西土家族等各大城市提供网站开发制作服务。

问题描述

给定一个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次幂怎么实现”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!

分享名称:SpringBoot整合MybatisPlus中矩阵乘法和矩阵的m次幂怎么实现
网站路径:https://www.cdcxhl.com/article12/jjigdc.html

成都网站建设公司_创新互联,为您提供标签优化外贸建站App开发软件开发手机网站建设网页设计公司

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

营销型网站建设