版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
./实验报告--矩阵运算一.实验目的。1.通过实践加强对程序设计语言课程知识点的理解和掌握,培养对课程知识综合运用能力、实际分析问题能力及编程能力,养成良好的编程习惯。2.通过实践进一步领会程序设计的特点和应用,提高运用C++语言以及面向对象知识解决实际问题的能力。3.通过实践掌握用C++语言编写面向对象的实用程序的设计方法,对面向对象方法和思想增加感性的认识;4.学会利用C++程序设计语言编写出一些短小、可靠的Windows实用程序,切实提高面向对象的程序设计能力。为后续的相关课程的学习打下基础。二.实验要求。1.学会建立模板类;2.实现矩阵的"加"、"减"、"乘"、"数乘"、"转置";3.动态存分配并用随机数填充;4.注意"加"、"减"、"乘"要进行条件的判断;三.设计思路。3.1算法基本流程获取用户输入的矩阵1的行数和列数,动态生成一个一维数组利用随机数生成数组成员,并利用两个循环输出数组,使其符合矩阵的格式矩阵2同矩阵1的处理方法通过两个矩阵的行数和列数比较来判断能否进行加减乘等运算,如不能,输出相关信息如能够进行计算,则利用数组进行相应运算,并按照正确格式输出通过改变一维数组中元素的顺序来实现转置并输出3.2算法流程图四.基本界面。五.关键代码。5.1关键类的声明classCMatrixclass{public: CMatrixclass<> { intm_Row=0;//行 intm_Col=0;//列 m_pElements=NULL;//一维数组 }; virtual~CMatrixclass<> { delete[]m_pElements; }public: intm_Row; intm_Col; int*m_pElements;};5.2关键函数代码voidCMyView::OnCHECKadd<>{ m_nums.SetCheck<0>; m_combine.SetCheck<0>; m_subtrict.SetCheck<0>; }voidCMyView::OnCHECKsubtrict<>{ m_add.SetCheck<0>; m_combine.SetCheck<0>; m_nums.SetCheck<0>; }voidCMyView::OnCHECKcombine<>{ m_add.SetCheck<0>; m_nums.SetCheck<0>; m_subtrict.SetCheck<0>;}voidCMyView::OnCHECKnums<>{ m_add.SetCheck<0>; m_combine.SetCheck<0>; m_subtrict.SetCheck<0>; }voidCMyView::OnBUTTONcompute<>{ UpdateData<TRUE>; //TODO:Addyourcontrolnotificationhandlercodehere if<m_add.GetState<>==1> { if<op1->imax!=op2->imax||op1->jmax!=op2->jmax||op1==NULL||op2==NULL> { m_result="行数列数不等无法相加!"; } else { matrix<int>c<op1->imax,op1->jmax>; c=*op1+*op2; m_result="matrix1+matrix2"; m_result+="\r\n"; m_result+=c.my_show<>; } } elseif<m_subtrict.GetState<>==1> { if<op1->imax!=op2->imax||op1->jmax!=op2->jmax||op1==NULL||op2==NULL> { m_result="行数列数不等无法相减!"; } else { matrix<int>c<op1->imax,op1->jmax>; c=*op1-*op2; m_result="matrix1-matrix2"; m_result+="\r\n"; m_result+=c.my_show<>; } } elseif<m_combine.GetState<>==1> { if<op1->jmax!=op2->imax||op1==NULL||op2==NULL> { m_result="以上无法相乘!"; } else { matrix<int>c<op1->imax,op2->jmax>; c=<*op1>*<*op2>; m_result="matrix1*matrix2"; m_result+="\r\n"; m_result+=c.my_show<>; } } elseif<m_nums.GetState<>==1> { if<op2==NULL> { m_result="运算不出结果!"; } else { matrix<int>c<op2->imax,op2->jmax>;c=m_k*<*op2>; m_result="k*matrix2"; m_result+="\r\n"; m_result+=c.my_show<>; } } else { m_result="请先选定一个算法!"; } UpdateData<FALSE>; }voidCMyView::OnBUTTONrotate<>{ UpdateData<TRUE>; if<m_r1.GetState<>==1> { if<op1==NULL> { m_result="请先输入矩阵!"; } else { matrix<int>c=rotate<*op1>; m_result="matrix1转置"; m_result+="\r\n"; m_result+=c.my_show<>; } } elseif<m_r2.GetState<>==1> { if<op2==NULL>{ m_result="请先输入矩阵!"; } else { matrix<int>c=rotate<*op2>; m_result="matrix2转置"; m_result+="\r\n"; m_result+=c.my_show<>; } } else { m_result="请选择一个矩阵!"; } UpdateData<FALSE>;}voidCMyView::OnCHECKr1<>{ UpdateData<TRUE>; m_r2.SetCheck<0>; UpdateData<FALSE>; }voidCMyView::OnCHECKr2<>{ UpdateData<TRUE>; m_r1.SetCheck<0>; UpdateData<FALSE>; }六.实验心得与编程收获。这个程序是相对简单一些的,但在编写的过程中我仍然感觉收获很多.首先是合理运用一维数组,利用它来进行矩阵的相关运算,并且最后利用数组来输出矩阵,这也加强了我运用CString的能力.然后在制作界面方面使我更加得心应手,能够快速完成界面及相关的属性设置.最后还有动态生成矩阵方面也帮我复习了从前的知识.七.总结展望与参考书目。7.1总结展望尽管这次的矩阵并不完善,只能作一些简单的运算,但是我想矩阵在今后无论学习还是工作
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 染色师成果转化模拟考核试卷含答案
- 道岔钳工安全操作竞赛考核试卷含答案
- 脚轮制作工安全风险水平考核试卷含答案
- 酱卤肉制品加工工操作管理评优考核试卷含答案
- 纤维调施胶干燥工安全培训模拟考核试卷含答案
- 2025年太阳能组件生产装备项目合作计划书
- 2025年镀铬板(卷)合作协议书
- 中国垃圾填埋场治理行业市场前景预测及投资价值评估分析报告
- 信息安全与加密教学课件
- 2025年青海省西宁市中考生物真题卷含答案解析
- 大数据安全技术与管理
- 2026年中小学校长校园安全管理培训考试题及答案
- 2025年山东建筑大学思想道德修养与法律基础期末考试模拟题必考题
- 江西省赣州地区2023-2024学年七年级上学期期末英语试(含答案)
- 2025年香港沪江维多利亚笔试及答案
- 述职报告中医
- 患者身份识别管理标准
- 松下Feeder维护保养教材
- 汽车融资贷款合同范本
- 2025租房合同范本下载(可直接打印)
- 《陆上风电场工程概算定额》NBT 31010-2019
评论
0/150
提交评论