用C语言编写程序(两个矩阵相加)

用C语言编写程序(两个矩阵相加),第1张

用C语言编写程序(两个矩阵相加)代码如下:

/**

MatrixAddition.c

实现两个矩阵相加

*/

#include<stdio.h>

const int COLS=3

void printMatirx(int *pArray,int rows,int cols)

void printMatirx2(int (*pArray)[COLS],int rows)

int main()

{

int A[3][4]={{15,10,9,12},

{18,14,8,7},

{16,13,6,11}}

printf("矩阵A=\n")

printMatirx(A,3,4)

int B[3][4]={{4,3,5,2},

{0,9,6,1},

{5,7,2,6}}

printf("矩阵B=\n")

printMatirx(B,3,4)

int C[3][4]

int i,j

//矩阵相加:两个矩阵必须行数和列数一样才能相加,

//和矩阵的每个元素分别是两个矩阵对应的元素的和

printf("矩阵A+矩阵B=\n")

for(i=0i<3i++)//控制行

{

for(j=0j<4j++)

{

C[i][j]=A[i][j]+B[i][j]

//printf("%3d",C[i][j])//输出结果

}

//        printf("\n")

}

int (*p)[COLS]=C

printMatirx2(p,3)

/*结果应为:

19 13 14 14

18 23 14  8

21 20  8 17

*/

printf("矩阵C-矩阵A=\n")

for(i=0i<3i++)//控制行

{

for(j=0j<4j++)

{

printf("%3d",C[i][j]-A[i][j])//输出结果

}

printf("\n")

}

/*结果应为:

4  3  5  2

0  9  6  1

5  7  2  6

*/

//矩阵数乘:

int D[3][4]

printf("矩阵D:\n")

for(i=0i<3i++)//控制行

{

for(j=0j<4j++)

{

D[i][j]=1

printf("%d\t", D[i][j])//输出结果

}

printf("\n")

}

int mul

printf("矩阵D数乘以:")

scanf("%d",&mul)

printf("矩阵D数乘以%d=\n",mul)

for(i=0i<3i++)//控制行

{

for(j=0j<4j++)

{

D[i][j]=D[i][j]*mul

printf("%d\t", D[i][j])//输出结果

}

printf("\n")

}

return 0

}

扩展资料:

C语言矩阵加减法函数:

void matrix_a(double **a_matrix, const double **b_matrix, const double **c_matrix,int krow, int kline, int ktrl)

////////////////////////////////////////////////////////////////////////////

//  a_matrix=b_matrix+c_matrix

//   krow   :行数

//   kline  :列数

//   ktrl   :大于0: 加法  不大于0:减法

////////////////////////////////////////////////////////////////////////////

{

int k, k2

for (k = 0k <krowk++) 

{

for(k2 = 0k2 <klinek2++)

     

{

a_matrix[k][k2] = b_matrix[k][k2]

             

+ ((ktrl >0) ? c_matrix[k][k2] : -c_matrix[k][k2])

}

}

}

参考资料:

百度百科-C语言

#include<stdio.h>

void main()

{

int a[15][15],i,j,k,t,b

printf("请输入一个3行3列的矩阵:\n")

/*for(i=0i<3i++)

for(j=0j<3j++)

scanf("%d",&a[i][j])

printf("请输入另一个3行3列的矩阵\n")

for(k=0k<3k++)

for(t=0t<3t++)

scanf("%d",&a[k][t])*///<----此处覆盖掉了矩阵1;

for(i=0i<3i++)

for(j=0j<3j++)

scanf("%d",&a[i][j])

printf("请输入另一个3行3列的矩阵\n")

for(k=0k<3k++)

for(t=0t<3t++)

scanf("%d",&a[k+3][t+3])

printf("矩阵【1】\n")

for(i=0i<3i++){

for(j=0j<3j++)

printf("%d ",a[i][j])

printf("\n")

}

printf("矩阵【2】\n")

for(i=0i<3i++){

for(j=0j<3j++)

printf("%d ",a[i+3][j+3])

printf("\n")

}

printf("请选择要进行的运算:1 相加 2 相乘\n")

scanf("%d",&b)

//<----------楼主此处以下的四个for一一嵌套算出来的结果没什么意义。

if(b==1)

{

printf("相加:\n")

for(i=0i<3i++)

for(j=0j<3j++)

a[i][j]=a[i][j]+a[i+3][j+3]

for(i=0i<3i++){

for(j=0j<3j++)

printf("%d\t",a[i][j])

printf("\n")}

}

if(b==2)

{

printf("相乘:\n")

for(i=0i<3i++)

for(j=0j<3j++)

a[i+6][j+6] = a[i][0]*a[3][j+3] + a[i][1]*a[4][j+3] + a[i][2]*a[5][j+3]

for(i=0i<3i++){

for(j=0j<3j++)

printf("%d\t",a[i+6][j+6])

printf("\n")

}

}

}

复制后可直接编译运行,结果如下:格式可自行修改。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/11736202.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存