用C语言编写程序(两个矩阵相加)
用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=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
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=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
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=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
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=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
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 = 0; k < krow; k++)
{
for(k2 = 0; k2 < kline; k2++)
{
a_matrix[k][k2] = b_matrix[k][k2]
+ ((ktrl > 0) ? c_matrix[k][k2] : -c_matrix[k][k2]);
}
}
}
参考资料:
2013-05-23
void main()
{
int a[3][3];
int b[3][3];
int c[3][3];
int *p1,*p2,*p3;
p1=&a[0][0];
p2=&b[0][0];
p3=&c[0][0];
int i,k;
printf ("请输入第一个矩阵的值:\n");
for (i=0;i<3;i++)
{
for (k=0;k<3;k++)
{
printf ("请输入第[%d][%d]",i,k);
scanf ("%d",&a[i][k]);
}
}
printf ("请输入第二个矩阵的值:\n");
for (i=0;i<3;i++)
{
for (k=0;k<3;k++)
{
printf ("请输入第[%d][%d]",i,k);
scanf ("%d",&b[i][k]);
}
}
printf ("第一个矩阵为:\n");
for (i=0;i<3;i++)
{
for (k=0;k<3;k++)
{
printf ("%4d",(a[i][k]));
}
printf ("\n");
}
printf ("第二个矩阵为:\n");
for (i=0;i<3;i++)
{
for (k=0;k<3;k++)
{
printf ("%4d",b[i][k]);
}
printf ("\n");
}
for (i=0;i<3;i++)
{
for (k=0;k<3;k++)
{
*p3=*p1+*p2;
p1++;
p2++;
p3++;
}
}
printf ("\n两个矩阵相加后为:\n");
for (i=0;i<3;i++)
{
for (k=0;k<3;k++)
{
printf ("%4d",c[i][k]);
}
printf ("\n");
}
}
2013-05-23
void main()
{
int i,j;
int a[3][3],b[3][3],c[3][3]
for(i=0;i<3;i++)//给a[3][3]赋值
{
{
for(j=0;j<3;j++)
scanf("%d",&a[i][j]);
}
}
for(i=0;i<3;i++)//给b[3][3]赋值
{
{
for(j=0;j<3;j++)
scanf("%d",&b[i][j]);
}
}
for(i=0;i<3;i++)//a[3][3]与b[3][3]相加
{
for(j=0;j<3;j++)
{
c[i][j]=a[i][j]+b[i][j];//值赋给c[3][3]
}
}
for(i=0;i<3;i++)//循环打印出c[3][3]的值
{
for(j=0;j<3;j++)
printf("c[%d][%d]=%d\n",i,j,c[i][j]);
}
}
#include <stdio.h>
void main()
{
int i,j;
int a[3][3],b[3][3],c[3][3]
for(i=0;i<3;i++)//给a[3][3]赋值
{
{
for(j=0;j<3;j++)
scanf("%d",&a[i][j]);
}
}
for(i=0;i<3;i++)//给b[3][3]赋值
{
{
for(j=0;j<3;j++)
scanf("%d",&b[i][j]);
}
}
for(i=0;i<3;i++)//a[3][3]与b[3][3]相加
{
for(j=0;j<3;j++)
{
c[i][j]=a[i][j]+b[i][j];//值赋给c[3][3]
}
}
for(i=0;i<3;i++)//循环打印出c[3][3]的值
{
for(j=0;j<3;j++)
printf("c[%d][%d]=%d\n",i,j,c[i][j]);
}
}