?? 矩陣計算.cpp
字號:
#include<iostream.h>
#include<iomanip.h>
template<typename T1,typename T2> void inverse(T1 *mat1,T2*mat2,int a,int b);
template<typename T1,typename T2> void multi(T1 *mat1,T2 *mat2,T2 *re,int a,int b,int c);
template<typename T> void output(T*mat,char*s,int a,int b);
void main(){
int mid[6][3],re[6][4];
int ma1[3][6]={8,10,12,23,1,3,5,7,9,2,4,6,34,45,56,2,4,6};
int ma2[3][4]={3,2,1,0,-1,-2,9,8,7,6,5,4};
char *s1="result";
char *s2="middle";
inverse(ma1,mid,6,3);
multi(mid,ma2,re,6,3,4);
output(ma1,"matrix1",3,6);
output(mid,s2,6,3);
output(ma2,"matrix2",3,4);
output(re,s1,6,4);
return;
}
template<typename T1,typename T2> void inverse(T1 *mat1,T2 *mat2,int a,int b){
int i,j;
for(i=0;i<b;i++)
for(j=0;j<a;j++)
mat2[j][i]=mat1[i][j];
return;
}
template<typename T1,typename T2> void multi(T1 *mat1,T2*mat2,T2*re,int a,int b,int c){
int i,j,k;
for(i=0;i<a;i++){
for(j=0;j<c;j++){
re[i][j]=0;
for(k=0;k<b;k++)
re[i][j]+=mat1[i][k]*mat2[k][j];
}
}
return;
}
template<typename T>void output(T*mat,char*s,int a,int b){
cout<<s<<endl;
for(int i=0;i<a;i++){
for(int j=0;j<b;j++)
cout<<setw(6)<<mat[i][j];
cout<<endl;
}
return;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -