矩阵相加c语言
⑴ c语言 求矩阵各行各列的和
思路:求矩阵各行的和时,矩阵的行先不变,利用for循环依次遍历该行的每一列元素累加求和;求矩阵各列的和时,矩阵的列先不变,利用for循环依次遍历该列的每一行元素累加求和。
参考代码:
#include<stdio.h>
intSr(inta[3][5],intn)//求矩阵n行的累加和
{
inti,j,c=0;
for(j=0;j<5;j++)
c+=a[n][j];
returnc;
}
intSc(inta[3][5],intn)//求矩阵n列的累加和
{
inti,j,c=0;
for(i=0;i<3;i++)
c+=a[i][n];
returnc;
}
intmain()
{
inti,j,a[3][5]={1,3,5,7,9,2,4,6,8,10,3,5,8,7,6};
for(i=0;i<3;i++){
for(j=0;j<5;j++)
printf("%d",a[i][j]);
printf(" ");
}
printf("各行的累加和为: ");
for(i=0;i<3;i++)
printf("%d",Sr(a,i));
printf(" 各列的累加和为: ");
for(i=0;i<5;i++)
printf("%d",Sc(a,i));
return0;
}
/*
输出:
13579
246810
35876
各行的累加和为:
253029
各列的累加和为:
612192225
*/
⑵ 用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= ");
printMatirx(A,3,4);
int B[3][4]={{4,3,5,2},
{0,9,6,1},
{5,7,2,6}};
printf("矩阵B= ");
printMatirx(B,3,4);
int C[3][4];
int i,j;
//矩阵相加:两个矩阵必须行数和列数一样才能相加,
//和矩阵的每个元素分别是两个矩阵对应的元素的和
printf("矩阵A+矩阵B= ");
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(" ");
}
int (*p)[COLS]=C;
printMatirx2(p,3);
/*结果应为:
19 13 14 14
18 23 14 8
21 20 8 17
*/
printf("矩阵C-矩阵A= ");
for(i=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
printf("%3d",C[i][j]-A[i][j]);//输出结果
}
printf(" ");
}
/*结果应为:
4 3 5 2
0 9 6 1
5 7 2 6
*/
//矩阵数乘:
int D[3][4];
printf("矩阵D: ");
for(i=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
D[i][j]=1;
printf("%d ", D[i][j]);//输出结果
}
printf(" ");
}
int mul;
printf("矩阵D数乘以:");
scanf("%d",&mul);
printf("矩阵D数乘以%d= ",mul);
for(i=0;i<3;i++)//控制行
{
for(j=0;j<4;j++)
{
D[i][j]=D[i][j]*mul;
printf("%d ", D[i][j]);//输出结果
}
printf(" ");
}
return 0;
}
(2)矩阵相加c语言扩展阅读:
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语言编程实现矩阵相加、相乘
矩阵相加会简单点,设a[2][3]和b[2][3],只要在相应的地方相加就行了,
for(i=0;i<2;i++)
for(j=0;j<3;j++)
c[i][j]=a[i][j]+b[i][j];
两矩阵相乘,
int a[][3]={1,2,3,4,5,6,7,8,9};//A为N×P矩阵,
//假设是3*3的矩阵
int b[][5]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
//B为P×M矩阵,假设是3*5的矩阵
int c[3][5]={0};//结果矩阵3*5
for(int i=0;i<3;i++)
for(int j=0;j<5;j++)
for(int k=0;k<3;k++)
c[i][j]+=a[i][k]*b[k][j];
⑷ C语言中求两个矩阵的和
C语言中求两个矩阵的和具体如下:
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void main()
{
int a[3][3];
int b[3][3];
int i,j,c,x;
printf(" 求两个矩阵之和 ");
printf("请选择输入方式 ");
printf("0为随机自主输入,1为人工输入 ");
scanf("%d",&x);
if(x==1)
{
printf("请输入两个3*3矩阵,以回车结束每个数字的输入 ");
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
printf("a[%d][%d]=",i,j);
scanf("%d",&a[i][j]);
}
}
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
printf("b[%d][%d]=",i,j);
scanf("%d",&b[i][j]);
}
}
}
if(x==0)
{
srand((unsigned int)time(NULL));
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
a[i][j]=rand()%100+1;
}
}
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
printf("a[%d][%d]=",i,j);
printf("%d
",a[i][j]);
}
}
srand((unsigned int)time(NULL));
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
b[i][j]=rand()%100+1;
}
}
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
printf("b[%d][%d]=",i,j);
printf("%d ",b[i][j]);
}
}
}
for(i=0;i<=2;i++)
{
for(j=0;j<=2;j++)
{
c=a[i][j]+b[i][j];
printf(" %d ",c);
}
}
}