- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
名称
编程题6_2:矩阵类中的运算符重载
备注
描述
设计一个矩阵类,要求矩阵类中重载运算符加(+)和赋值(=),主函数定义类对象并调用重载的运算符。
提示: (1) 本题考虑可加(即加与被加矩阵的行列数必须分别相等)和可赋值(等号左值和右值的行列数必须分别相等)情况,其他情况输出 “ program terminated! ” (2) 要求分别输入矩阵 am 和 bm 的行列数,各矩阵元素,分别计算 cm=am+bm;am=bm; 并进行输出 (3) 定义相应的构造函数和析构函数 (4) 类中的成员变量应当有三个: int row,col; 分别表示矩阵的行数和列数,另外还需要定义一个一级指针m用来申请动态空间,存放 row*col 个整数
( 5 )程序最前面的文件包含提交到系统中请用下面代码:
#include iostreamusing namespace std;#include stdlib.h
但是在VC++环境下本地测试时,如果你的程序中用到了友元,则要将头文件用下面的代码(提交时再修改为上面的三行):
#include iostream.h#include stdlib.h
即本地调试运行正确无误后,再将头文件部分改掉提交!
(6) 请根据提供的主函数,给出相应的类定义和函数定义。 int main(){int row_a,col_a,row_b,col_b;cout请输入am矩阵的行数和列数:;cinrow_acol_a;Matrix am(row_a,col_a);cout请输入bm矩阵的行数和列数:;cinrow_bcol_b;Matrix bm(row_b,col_b),cm;coutam:endl;am.disp();coutbm:endl;bm.disp();cm=am+bm;coutcm=am+bm:endl;cm.disp();am=bm;coutam=bm:endl;am.disp();return 0;}
(7) 类的成员函数 disp 的代码如下:
void Matrix::disp()
{
for(int i=0;irow;i++)
{
cout\t;
for(int j=0;jcol;j++)
cout*(m+i*col+j)\t;
coutendl;
}
}
在保存并预览之后,点开:“测试用例”选项卡,再选择下方的“添加”,加入两组测试用例
第一个测试用例:输入部分:3 3回车1 2 3 4 5 6 7 8 93 3回车9 8 7 6 5 4 3 2 1输出部分:请输入am矩阵的行数和列数:请输入该矩阵元素:请输入bm矩阵的行数和列数:请输入该矩阵元素:am: 1 2 3 4 5 6 7 8 9 bm: 9 8 7 6 5 4 3 2 1 cm=am+bm: 10 10 10 10 10 10 10 10 10 am=bm: 9 8 7 6 5 4 3 2 1 第二个测试用例:输入部分:3 4回车1 2 3 4 5 6 7 8 9 10 11 123 3回车9 8 7 6 5 4 3 2 1输出部分:请输入am矩阵的行数和列数:请输入该矩阵元素:请输入bm矩阵的行数和列数:请输入该矩阵元素:am: 1 2 3 4 5 6 7 8 9 10 11 12 bm: 9 8 7 6 5 4 3 2 1 program terminated!
参考源程序代码
#include iostream //说明:在VC++下请将此句改为#include iostream.h
using namespace std; //说明:在VC++下请将此句注释
#include stdlib.h
class Matrix
{
int *m,row,col;
public:
Matrix(int ,int);
Matrix();
~Matrix();
friend Matrix operator+(Matrix ,Matrix );
Matrix operator=(Matrix );
void disp();
};
Matrix::Matrix()
{
row=col=0;
m=NULL;
}
Matrix::Matrix(int r,int c)
{
row=r;col=c;
m=new int[row*col];
cout请输入该矩阵元素:;
for(int i=0;irow;i++)
for(int j=0;jcol;j++)
cinm[i*col+j];
}
Matrix
您可能关注的文档
- 电工复审试+答案.doc
- 电工多量程直电压表电流表的设计.doc
- 电工学 选.doc
- 电工学 33节点电压法.ppt
- 电工学(22.doc
- 电工学(电技术)第七版课件chapter14.doc
- 电工学-第章直流稳压电源.ppt
- 电工学(Ⅱ:电子技术.doc
- 电工基础高教程.ppt
- 电工学-第1章电力电子技术.ppt
- 小学毕业纪念册.pptx
- 生日宴百日宴主题模板.pptx
- 2025届高考地理一轮复习: 从人地作用看自然灾害 专题练习题(含答案解析).docx
- 2025届高中历史一轮复习:中国现代史 专题测试卷(含答案解析).docx
- 2025届高中历史一轮复习:世界近代史 专题测试卷(含答案解析).docx
- 2025届高中历史一轮复习:民国 专题测试卷(含答案解析).docx
- 2025届高考地理一轮复习: 自然环境的特征 专题练习题(含答案解析).docx
- 2025届高中历史一轮复习:世界古代史 专题测试卷(含答案解析).docx
- 2025届高考地理一轮复习: 地理环境与区域发展 专题练习题(含答案解析).docx
- 2025届高考地理一轮复习: 水体运动的影响 专题练习题(含答案解析).docx
文档评论(0)