C++中實(shí)現(xiàn)矩陣的加法和乘法實(shí)例
更新時(shí)間:2017年03月31日 16:46:17 作者:不見x的心
這篇文章主要介紹了C++中實(shí)現(xiàn)矩陣的加法和乘法實(shí)例的相關(guān)資料,需要的朋友可以參考下
C++中實(shí)現(xiàn)矩陣的加法和乘法實(shí)例
實(shí)現(xiàn)效果圖:

實(shí)例代碼:
#include<iostream>
using namespace std;
class Matrix
{
int row;//矩陣的行
int col;//矩陣的列
int **a;//保存二維數(shù)組的元素
public:
Matrix();//默認(rèn)構(gòu)造函數(shù)
Matrix(int r, int c);
Matrix(const Matrix &is);//拷貝構(gòu)造函數(shù)
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("請(qǐng)輸入數(shù):\n");
for (int i = 0; i < row; i++)
for (int j = 0; j < col; j++)
cin >> a[i][j];
}
Matrix::Matrix(const Matrix & is)
{//拷貝構(gòu)造函數(shù)
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;
}
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
C語言中send()函數(shù)和sendto()函數(shù)的使用方法
這篇文章主要介紹了C語言中send()函數(shù)和sendto()函數(shù)的使用方法,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09
Matlab實(shí)現(xiàn)三維投影繪制的示例代碼
這篇文章系小編為大家?guī)砹艘粋€(gè)三維投影繪制函數(shù)(三視圖繪制),函數(shù)支持三維曲線、曲面、三維多邊形、參數(shù)方程曲線、參數(shù)方程曲面的投影繪制,需要的可以參考一下2022-08-08
C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理
這篇文章主要介紹了C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
2023-02-02
C++程序自動(dòng)重啟的實(shí)現(xiàn)代碼
自動(dòng)重啟原理很簡(jiǎn)單,用一個(gè)進(jìn)程監(jiān)控另一個(gè)進(jìn)程,掛了就再啟動(dòng)一個(gè),細(xì)節(jié)也不算多,主要是正確判斷進(jìn)程狀態(tài)和啟動(dòng)方式,本文就給大家講講C++程序自動(dòng)重啟的實(shí)現(xiàn)方法,文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下
2024-04-04
手把手教你實(shí)現(xiàn)一個(gè)C++單鏈表
鏈表是一種數(shù)據(jù)結(jié)構(gòu),用于數(shù)據(jù)的存儲(chǔ)。這篇文章主要為大家介紹了如何實(shí)現(xiàn)一個(gè)C++單鏈表,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下
2022-11-11
C++求所有頂點(diǎn)之間的最短路徑(用Dijkstra算法)
這篇文章主要為大家詳細(xì)介紹了C++用Dijkstra算法求所有頂點(diǎn)之間的最短路徑,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
2020-04-04 
