时间:2021-05-20
C++中实现矩阵的加法和乘法实例
实现效果图:
实例代码:
#include<iostream>using namespace std;class Matrix{ int row;//矩阵的行 int col;//矩阵的列 int **a;//保存二维数组的元素public: Matrix();//默认构造函数 Matrix(int r, int c); Matrix(const Matrix &is);//拷贝构造函数 void Madd(const Matrix &is);//矩阵加 Matrix Mmul(const Matrix &is);//矩阵乘 void display();//显示矩阵元素};Matrix::Matrix(int r, int c){ row = r; col = c; a = (int **)malloc(sizeof(int*)*row); for (int r = 0; r < row; r++) { *(a + r) = (int*)malloc(sizeof(int)*col); } printf("请输入数:\n"); for (int i = 0; i < row; i++) for (int j = 0; j < col; j++) cin >> a[i][j];}Matrix::Matrix(const Matrix & is){//拷贝构造函数 row = is.row; col = is.col; a = new int*[row]; for (int i = 0; i < row; i++) { a[i] = new int[col]; } a = is.a;}void Matrix::Madd(const Matrix & is){ if (row != is.row || col != is.col)//判断两矩阵是否符合相加条件 { cout << "相加的矩阵必须行和列一致"; } else { for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { a[i][j] += is.a[i][j]; } } }}Matrix Matrix::Mmul(const Matrix & is){ Matrix M3(this->row, is.col); if (this->col != is.row)//判断是否符合相乘条件 { cout << "不符合两矩阵相乘的条件"; } else { for (int i = 0; i < M3.row; i++) { for (int j = 0; j < M3.col; j++) { M3.a[i][j] = 0; for (int n = 0; n < is.row; n++) { M3.a[i][j] += this->a[i][n] * is.a[n][j]; } } } } return M3;}void Matrix::display(){//输出矩阵 for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { cout << a[i][j] << " "; } cout << endl; } cout << endl;}int main(){ Matrix m1(3, 3); m1.display(); Matrix m2(3, 3); m2.display(); Matrix m3(3, 2); m3.display(); cout << "m1+m2=" << endl; m1.Madd(m2); m1.display(); Matrix m4(m1.Mmul(m3)); cout << "m1*m3=" << endl; m4.display(); system("pause"); return 0;}感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python实现矩阵加法和乘法的方法。分享给大家供大家参考,具体如下:本来以为python的矩阵用list表示出来应该很简单可以搞。。其实发现有大
本文实例讲述了C#实现矩阵加法、取负、数乘、乘法的方法。分享给大家供大家参考。具体如下:1.几个基本函数1)判断一个二维数组是否为矩阵:如果每行的列数都相等则是
本文实例讲述了C#实现矩阵乘法的方法。分享给大家供大家参考。具体如下:staticdouble[][]MatrixMultiplication(double[]
分别使用C++中的运算符重载的方法来实现大数之间的数学运算,包括加法、减法、乘法、除法、n次方、取模、大小比较、赋值以及输入流、输出流的重载。。并且使用这个大数
本文实例讲述了Java实现的矩阵乘法。分享给大家供大家参考,具体如下:思路:矩阵乘法的前提是:前一矩阵的行数==后一矩阵的列数(rows==cols)在满足前提