1.每日打卡-12.每日打卡-2.13.每日打卡-2.24.每日打卡-35.每日打卡-5.26.每日打卡-5.17.每日打卡-4.28.每日打卡-4.19.每日打卡-11.210.每日打卡-11.111.每日打卡-1012.每日打卡-913.每日打卡-8.214.每日打卡-8.115.每日打卡-716.每日打卡-617.每日打卡-22.118.每日打卡-22.219.每日打卡-21.420.每日打卡-21.221.每日打卡-21.322.每日打卡-21.123.每日打卡-20.224.每日打卡-20.125.每日打卡-1926.每日打卡-1827.每日打卡-1728.每日打卡-1629.每日打卡-1530.每日打卡-1431.每日打卡-1332.每日打卡-1233.每日打卡-3334.每日打卡-3235.每日打卡-3136.每日打卡-3037.每日打卡-2938.每日打卡-2839.每日打卡-2740.每日打卡-26
41.每日打卡-25
42.每日打卡-24.243.每日打卡-24.144.每日打卡-23一.问题描述
线性代数中的矩阵可以表示为一个row*column的二维数组,当row和column均为1时,退化为一个数,当row为1时,为一个行向量,当column为1时,为一个列向量。
建立一个整数矩阵类matrix,其私有数据成员如下:
int row;
int column;
int **mat;
建立该整数矩阵类matrix构造函数;
建立一个 *(乘号)的运算符重载,以便于对两个矩阵直接进行乘法运算;
建立输出函数void display(),对整数矩阵按行进行列对齐输出,格式化输出语句如下:
cout<<setw(10)<<mat[i][j];
主函数里定义三个整数矩阵类对象m1、m2、m3.
输入格式:
分别输入两个矩阵,分别为整数矩阵类对象m1和m2。
每个矩阵输入如下:
第一行两个整数 r c,分别给出矩阵的行数和列数
接下来输入r行,对应整数矩阵的每一行
每行输入c个整数,对应当前行的c个列元素
输出格式:
整数矩阵按行进行列对齐(宽度为10)后输出。
判断m1和m2是否可以执行矩阵相乘运算。
若可以,执行m3=m1*m2运算之后,调用display函数,对m3进行输出。
若不可以,输出"Invalid Matrix multiplication!"
提示:输入或输出的整数矩阵,保证满足row>=1和column>=1。
输入样例:
4 5
1 0 0 0 5
0 2 0 0 0
0 0 3 0 0
0 0 0 4 0
5 5
1 2 3 4 5
2 3 4 5 6
3 4 5 6 7
4 5 6 8 9
5 6 7 8 9
输出样例:
26 32 38 44 50
4 6 8 10 12
9 12 15 18 21
16 20 24 32 36
二.设计思路
三.流程图
四.伪代码
1
五.代码实现
#include <iostream>
#include <iomanip>
using namespace std;
class matrix{
private:
int row=0;
int column=0;
int** mat;
public:
friend istream& operator>> (istream& in, matrix& a) {
in >> a.row >> a.column;
a.mat = new int* [a.row];//申请动态内存空间
for (int i = 0; i < a.column; i++) a.mat[i] = new int[a.column];
for (int i = 0; i < a.row; i++) {
for (int j = 0; j < a.column;j++) {
in >> a.mat[i][j];
}
}
return in;
}
friend matrix operator* (matrix& a,matrix& b) {
matrix c;
c.row = a.row;
c.column = b.column;
c.mat = new int* [a.row];
for (int i = 0; i < a.row; i++) c.mat[i] = new int[b.column];//申请动态内存空间
for (int i = 0; i < a.row; i++) {
for (int j = 0; j < b.column; j++) {
int sum = 0;
for (int k = 0; k<a.column; k++) {
sum += a.mat[i][k] * b.mat[k][j];
}
c.mat[i][j] = sum;
}
}
return c;
}
void display() {
for (int i = 0; i < row; i++) {
for (int j = 0; j < column; j++) {
cout << setw(10) << mat[i][j];
}
cout << endl;
}
}
int putrow() {
return row;
}
int putcolumn() {
return column;
}
};
int main() {
matrix m1, m2, m3;
cin >> m1;
cin >> m2;
if (m1.putcolumn() == m2.putrow()) {
m3 = m1 * m2;
m3.display();
}
else cout << "Invalid Matrix multiplication!" << endl;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通