c語言輸入2行3列的矩陣A和3行4列的矩陣B,計算

2021-03-05 09:13:44 字數 4048 閱讀 8406

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 ...