C++中实现矩阵的加法和乘法实例-创新互联

C++中实现矩阵的加法和乘法实例

创新互联建站是一家集网站建设,夏津企业网站建设,夏津品牌网站建设,网站定制,夏津网站建设报价,网络营销,网络优化,夏津网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

实现效果图:

C++中实现矩阵的加法和乘法实例

实例代码:

#include
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;
}

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享名称:C++中实现矩阵的加法和乘法实例-创新互联
本文路径:http://csdahua.cn/article/dcpogj.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流