1樓:曉龍修理
解題過程如下:
#include ;#include
#define l 2,#define m 3,#define n 4
}printf("\n");}return;}int main(void)};
double b[m][n] = };double c[l][n] = };int i = 0, j = 0, k = 0;
printf("\ngenerate a[%d][%d]:\n", l, m);
genarr(&a[0][0], l, m);
printmatrix(&a[0][0], l, m);
printf("\ngenerate b[%d][%d]:\n", m, n);
}}printf("\ncalc c[%d][%d]:\n", l, n);
性質:矩陣相乘最重要的方法是一般矩陣乘積。它只有在第一個矩陣的列數(column)和第二個矩陣的行數(row)相同時才有意義 。
一般單指矩陣乘積時,指的便是一般矩陣乘積。一個m×n的矩陣就是m×n個數排成m行n列的一個數陣。由於它把許多資料緊湊地集中到了一起,所以有時候可以簡便地表示一些複雜的模型,如電力系統網路模型。
當矩陣a的列數(column)等於矩陣b的行數(row)時,a與b可以相乘。矩陣c的行數等於矩陣a的行數,c的列數等於b的列數。乘積c的第m行第n列的元素等於矩陣a的第m行的元素與矩陣b的第n列對應元素乘積之和。
當提及「矩陣相乘」或者「矩陣乘法」的時候,並不是指代這些特殊的乘積形式,而是定義中所描述的矩陣乘法。在描述這些特殊乘積時,使用這些運算的專用名稱和符號來避免表述歧義。
把給定的圖轉為鄰接矩陣,即a(i,j)=1當且僅當存在一條邊i->j。令c=a*a,那麼c(i,j)=σa(i,k)*a(k,j),實際上就等於從點i到點j恰好經過2條邊的路徑數(列舉k為中轉點)。
類似地,c*a的第i行第j列就表示從i到j經過3條邊的路徑數。同理,如果要求經過k步的路徑數,只需要二分求出a^k即可。
2樓:匿名使用者
#include
int main()}}
for(x=0;x<2;x++)
return 0;}
c語言:輸入矩陣2行3列的矩陣a和矩陣3行4列的矩陣b,計算矩陣的乘積
3樓:匿名使用者
#include
#include
#define l 2
#define m 3
#define n 4
void genarr(double *arr, int row, int col)
}void printmatrix(double *arr, int row, int col)
printf("\n");
}return;
}int main(void)
};double b[m][n] = };
double c[l][n] = };
int i = 0, j = 0, k = 0;
printf("\ngenerate a[%d][%d]:\n", l, m);
genarr(&a[0][0], l, m);
printmatrix(&a[0][0], l, m);
printf("\ngenerate b[%d][%d]:\n", m, n);
genarr(&b[0][0], m, n);
printmatrix(&b[0][0], m, n);
for (i = 0; i < l; ++i)}}
printf("\ncalc c[%d][%d]:\n", l, n);
printmatrix(&c[0][0], l, n);
return 0;}
c語言程式設計:輸入兩個3行4列的矩陣,計算並輸出兩個矩陣的和。
4樓:匿名使用者
#include
#define row 3//行數
#define col 4//列數
void plu**atrix(int a[row][col],int b[row][col],int c[row][col])
}printf("input %d*%d matrix b:\n",col,row);
for(i=0;i到c
printf("results:\n");
printmatrix(c);
return 0;
}測試:
矩陣乘法運算編寫一個函式實現矩陣a(2行3列)與矩陣b相乘(3行2列),乘積放在c陣列中,並輸出c陣列
5樓:匿名使用者
#include
void main(void)
;printf("輸入陣列a:
\n");
for(i=0;i<2;i++)
for(j=0;j<3;j++)
scanf("%d",&a[i][j]);
printf("輸入陣列b:\n");
for(i=0;i<3;i++)
for(j=0;j<2;j++)
scanf("%d",&b[i][j]);
for(i=0;i<2;i++)
}printf("輸出陣列c:\n");
for(i=0;i<2;i++)}
6樓:匿名使用者
練練手:
#include
int main()
;int b[3][2] = ;
int c[2][2] ;
int i=0,j=0,k=0;
for(;i<2;i++)
for(k = 0;k<2;k++)
}for(i=0;i<2;i++)
return 0;}
c語言 矩陣2行3列和3行2列相乘的值例如a[2][3]={2,3,4,5,6,7}b[3][2]={1,4,2,5,3,6}過程a[2][3]*b[3][2]
7樓:
int c[2][2] ;
int mulmat(int *a,int *b,int *c,int m,int n,int q)}}
int main()
printf("\n");};}
8樓:藍色**
這個應來該這麼寫
for(int i =0;i源組大小。比如a[m][n] b[x][y] 根據題目bai來說m*n是等於x*y的
if(b2>y)
a[a1][a2]*b[b1][b2];//這個就是他zhi們的乘法dao結果}
編寫一個函式實現矩陣a(2行3列)與矩陣b(3行2列)相乘,乘積放在c陣列中。在主
9樓:匿名使用者
#include
using namespace std;
int main()
;int b[3][2] = ;
int c[2][2] = ;
cout << "輸入矩陣a(
2行3列)元素的各個值:" << endl;
for(int i = 0;i < 2;i++)for(int j = 0;i < 3;j++)cin >> a[i][j];
cout << "輸入矩陣b(3行2列)元素的各個值:" << endl;
for(int i = 0;i < 3;i++)for(int j = 0;i < 2;j++)cin >> b[i][j];
for(int i = 0;i < 2;i++)for(int j = 0;i < 2;j++)for(int k = 0;k < 3;k++)c[ i ][ j ] += a[j][k] * b[k][j];
cout << "結果為: " << endl;
for(int i = 0;i < 2;i++)return 0;}
用c語言輸出3行3列矩陣a
include int main int avg 3 for int i 0 i 3 i printf n avg i float sum 3.0 for int i 0 i 3 i printf d avg i printf n return 0 include define n 3 void m...
矩陣乘法運算編寫函式實現矩陣A2行3列與矩陣B相乘
include void main void printf 輸入陣列a n for i 0 i 2 i for j 0 j 3 j scanf d a i j printf 輸入陣列b n for i 0 i 3 i for j 0 j 2 j scanf d b i j for i 0 i 2 i...
有兩個矩陣a和b,均為3行4列。求兩個矩陣之和。過載運算子使之能用於矩陣相加。如c a b
matlab,直接輸入矩陣不就能做嗎?不用程式設計吧 include using namespace std class matrix matrix int array 3 3 friend matrix operator matrix matrix friend istream operator ...