网站建设资讯

NEWS

网站建设资讯

定义矩阵相加函数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语言
本文路径:http://cdweb.net/article/higshj.html