/**
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语言
可能是系统不兼容。具体的 *** 作步骤为:
1、打开matrix应用程序,d出菜单中选择属性。
2、在属性窗口中选择兼容性选项,选择以兼容模式运行这个程序。
3、点击确定,应用程序就可以正常打开。
#include
#include
using namespace std
class jz
istream &operator>>(istream &is,jz &c)
ostream &operator<<(ostream &os,jz &c)
class jz
{
public:
jz(){}
friend jz operator+(const jz &a, const jz &b)//friend
friend ostream &operator<<(ostream &,jz &)
friend istream &operator>>(istream &,jz &)
jz(int a,int b,int c,int d,int e,int f)
{d1=ad2=bd3=cd4=dd5=ed6=f}
private:
int d1,d2,d3,d4,d5,d6
}
ostream &operator<<(ostream &output,jz &c)
{
output<<c.d1<<" p="" ?
#include
//using namespace std
class matrix
{
public:
matrix(){}
matrix(int array[3][3])
{
for(int i = 0i <3i++)
for(int j = 0j <3j++)
a[i][j] = array[i][j]
}
friend matrix operator + (matrix &,matrix &)
friend istream &operator >>(istream &input, matrix
&)
friend ostream &operator <<(ostream &output, matrix
&)
private:
int a[3][3]
}
matrix operator + (matrix &m1, matrix &m2)
{
int array[3][3]
for(int i = 0i <3i++)
for(int j = 0j <3j++)
array[i][j] = m1.a[i][j] + m2.a[i][j]
return matrix(array)
}
ostream &operator <<(ostream &output, matrix &m)
{
for(int i = 0i <3i++)
{
for(int j = 0j <3j++)
output<<m.a[i][j]<p="">
}
return output
}
istream &operator >>(istream &input, matrix &m)
{
for(int i = 0i <3i++)
for(int j = 0j <3j++)
input>>m.a[i][j]
return input
}
void main()
{
matrix m, m1,m2
cout<<"输入第一个数组:"<<endl<p="">
cin>>m1
cout<<"输入第二个数组:"<<endl<p="">
cin>>m2
m = m1 + m2
cout<<"两数组相加后结果:"<<endl<p="">
cout<<m<p="">
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)