定义矩阵相加函数c语言 矩阵求和c语言
c语言编写函数,用指针实现矩阵相加,并且将结果矩阵的指针作为函数返回值
#include "stdio.h"
创新互联是一家专业提供新郑企业网站建设,专注与成都网站制作、网站设计、H5响应式网站、小程序制作等业务。10年已为新郑众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。
#include "stdlib.h"
int **matrixAdd(int x1[][3],int x2[][3],int row,int col)
{
int **a=NULL;
int i,j;
a=(int **)malloc(row*sizeof(int *));
for(i=0;irow;i++)
a[i]=(int *)malloc(col*sizeof(int));
for(i=0;irow;i++)
for(j=0;jcol;j++)
a[i][j]=x1[i][j]+x2[i][j];
return a;
}
int main()
{
int a[2][3]={{1,2,3},{4,5,6}};
int b[2][3]={{11,12,13},{14,15,16}};
int ** result=NULL;
int i,j;
result=matrixAdd(a,b,2,3);
for(i=0;i2;i++)
{
for(j=0;j3;j++)
printf("%d ",result[i][j]);
printf("\n");
}
free(result);
result=NULL;
}
结果:
用C语言编写程序(两个矩阵相加)
用C语言编写程序(两个矩阵相加)代码如下:
/**
MatrixAddition.c
实现两个矩阵相加
*/
#includestdio.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;i3;i++)//控制行
{
for(j=0;j4;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;i3;i++)//控制行
{
for(j=0;j4;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;i3;i++)//控制行
{
for(j=0;j4;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;i3;i++)//控制行
{
for(j=0;j4;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]);
}
}
}
参考资料:
百度百科-C语言
C语言,我想定义一个函数实现矩阵相加功能,可是矩阵最少也要输入一个列数,我想让行列数都是变量,这个
#include stdio.h
#include string.h
#include stdlib.h
typedef struct matrix
{
int **array;
int row;
int column;
} MATRIX, *PMATRIX;
void addMatrix( PMATRIX a, PMATRIX b, PMATRIX c )
{
int i,j, k;
if ( a-row != b-row || a-column != b-column )
{
printf( "矩阵A %d*%d 与矩阵B %d*%d 大小不同,不支持加法运算\n",
a-row, a-column, b-row, b-column );
c-row = 0;
c-column = 0;
return;
}
c-row = a-row;
c-column = a-column;
c-array = (int**)malloc(c-row*sizeof(int*));
if ( c-array == NULL )
{
printf( "分配内存失败\n" );
c-row = 0;
c-column = 0;
return;
}
for( i=0; ia-row; i++ )
{
*(c-array+i) = (int*)malloc( c-column*sizeof(int) );
if ( *(c-array+i) == NULL )
{
printf( "分配内存失败\n" );
c-row = i-1;
freeMatrix( c );
return;
}
memset( *(c-array+i), 0, c-column*sizeof(int) );
for( j=0; ja-column; j++ )
*(*(c-array+i)+j) = *(*(a-array+i)+j) + *(*(b-array+i)+j);
}
}
文章名称:定义矩阵相加函数c语言 矩阵求和c语言
URL分享:http://pwwzsj.com/article/higshj.html