版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、-. z.实验报告-矩阵运算一实验目的。1.通过实践加强对程序设计语言课程知识点的理解和掌握,培养对课程知识综合运用能力、实际分析问题能力及编程能力,养成良好的编程习惯。2.通过实践进一步领会程序设计的特点和应用,提高运用C+语言以及面向对象知识解决实际问题的能力。3.通过实践掌握用C+语言编写面向对象的实用程序的设计方法,对面向对象方法和思想增加感性的认识;4.学会利用C+程序设计语言编写出一些短小、可靠的Windows实用程序,切实提高面向对象的程序设计能力。为后续的相关课程的学习打下根底。二实验要求。1.学会建立模板类;2.实现矩阵的加、减、乘、数乘、转置 ;3.动态存分配并用随机数填充
2、;4.注意加、减、乘 要进展条件的判断;三设计思路。3.1算法根本流程获取用户输入的矩阵1的行数和列数,动态生成一个一维数组利用随机数生成数组成员,并利用两个循环输出数组,使其符合矩阵的格式矩阵2同矩阵1的处理方法通过两个矩阵的行数和列数比拟来判断能否进展加减乘等运算,如不能,输出相关信息如能够进展计算,则利用数组进展相应运算,并按照正确格式输出通过改变一维数组中元素的顺序来实现转置并输出3.2算法流程图四根本界面。五关键代码。5.1关键类的声明class CMatri*classpublic:CMatri*class()int m_Row = 0; /行int m_Col = 0; /列m_
3、pElements = NULL; /一维数组;virtual CMatri*class()delete m_pElements;public:int m_Row;int m_Col;int * m_pElements;5.2关键函数代码void CMyView:OnCHECKadd() m_nums.SetCheck(0);m_bine.SetCheck(0);m_subtrict.SetCheck(0);void CMyView:OnCHECKsubtrict() m_add.SetCheck(0);m_bine.SetCheck(0);m_nums.SetCheck(0);void CM
4、yView:OnCHECKbine() m_add.SetCheck(0);m_nums.SetCheck(0);m_subtrict.SetCheck(0);void CMyView:OnCHECKnums() m_add.SetCheck(0);m_bine.SetCheck(0);m_subtrict.SetCheck(0);void CMyView:OnBUTTONpute() UpdateData(TRUE);/ TODO: Add your control notification handler code hereif(m_add.GetState()=1)if(op1-ima*
5、!=op2-ima*|op1-jma*!=op2-jma*|op1=NULL|op2=NULL)m_result=行数列数不等无法相加!;elsematri* c(op1-ima*,op1-jma*);c=*op1+*op2;m_result=matri*1+matri*2;m_result+=rn;m_result+=c.my_show();else if(m_subtrict.GetState()=1)if(op1-ima*!=op2-ima*|op1-jma*!=op2-jma*|op1=NULL|op2=NULL)m_result=行数列数不等无法相减!;elsematri* c(op
6、1-ima*,op1-jma*);c=*op1-*op2;m_result=matri*1-matri*2;m_result+=rn;m_result+=c.my_show();else if(m_bine.GetState()=1)if(op1-jma*!=op2-ima*|op1=NULL|op2=NULL)m_result=以上无法相乘!;elsematri* c(op1-ima*,op2-jma*);c=(*op1)*(*op2);m_result=matri*1*matri*2;m_result+=rn;m_result+=c.my_show();else if(m_nums.Get
7、State()=1)if(op2=NULL)m_result=运算不出结果!;elsematri* c(op2-ima*,op2-jma*); c=m_k*(*op2);m_result=k*matri*2;m_result+=rn;m_result+=c.my_show();elsem_result=请先选定一个算法!;UpdateData(FALSE);void CMyView:OnBUTTONrotate() UpdateData(TRUE);if(m_r1.GetState()=1)if(op1=NULL)m_result=请先输入矩阵!;elsematri* c=rotate(*op
8、1);m_result=matri*1转置;m_result+=rn;m_result+=c.my_show();else if(m_r2.GetState()=1)if(op2=NULL)m_result=请先输入矩阵!;elsematri* c=rotate(*op2);m_result=matri*2转置;m_result+=rn;m_result+=c.my_show();elsem_result=请选择一个矩阵!;UpdateData(FALSE);void CMyView:OnCHECKr1() UpdateData(TRUE);m_r2.SetCheck(0);UpdateDat
9、a(FALSE);void CMyView: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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 老年公寓副食品供应方案
- 重庆水上乐园品牌合作方案
- 石油炼化行业火灾演练方案
- 城市轨道交通电力系统安装方案
- 2024-2030年中国薯蓣皂素行业发展需求及投资战略分析报告
- 2024-2030年中国蓖麻种植市场产销现状及未来需求前景预测报告
- 2024-2030年中国药用辅料行业市场经营模式及投资价值调研报告
- 2024-2030年中国船用焚烧炉行业供需趋势及投资战略分析报告
- 2024-2030年中国舞蹈服装行业竞争战略及未来发展潜力预测报告权威版
- 2024-2030年中国自动变速箱行业供需分析及发展策略研究报告
- 护理质量管理常用工具
- 2022公路工程施工技术方案手册
- 亮化工程可行性研究报告
- 安全生产费用提取使用明细
- (完整版)病例演讲比赛PPT模板
- 直播合作协议
- 社科类课题申报工作辅导报告课件
- 头痛的诊治策略讲课课件
- 沙利文-内窥镜行业现状与发展趋势蓝皮书
- 国家开放大学一网一平台电大《建筑测量》实验报告1-5题库
- 规范诊疗服务行为专项整治行动自查表
评论
0/150
提交评论