面向对象程序设计课程实验报告材料3150.pdf
《面向对象程序设计课程实验报告材料3150.pdf》由会员分享,可在线阅读,更多相关《面向对象程序设计课程实验报告材料3150.pdf(49页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、实用标准文档 文案大全 课 程 实 验 报 告 课程名称:面向对象程序设计 院 系:专业班级:学 号:姓 名:指导教师:实用标准文档 文案大全 实用标准文档 文案大全 目 录 实验一.面向过程的整型栈编程.1 1.需求分析.1 1.1 题目要求.1 1.2 需求分析.2 2.系统设计.2 2.1 概要设计.2 2.2 详细设计.3 4.软件测试.4 5.特点与不足.5 5.1 技术特点.5 5.2 不足和改进的建议.5 6.过程和体会.5 6.1 遇到的主要问题和解决方法.5 6.2 课程设计的体会.5 7.源码和说明.6 7.1 文件清单及其功能说明.6 7.2 用户使用说明书.6 7.3
2、源代码.6 实验二.面向对象的整型栈编程.12 1.需求分析.12 1.1 题目要求.12 1.2 需求分析.12 2.系统设计.13 2.1 概要设计.13 2.2 详细设计.13 3.软件开发.14 4.软件测试.14 5.特点与不足.14 5.1 技术特点.14 5.2 不足和改进的建议.15 6.过程和体会.15 6.1 遇到的主要问题和解决方法.15 6.2 课程设计的体会.15 实用标准文档 文案大全 7.源码和说明.15 7.1 文件清单及其功能说明.15 7.2 用户使用说明书.15 7.3 源代码.15 实验三.基于算符重载的整型栈编程.19 1.需求分析.19 1.1 题目
3、要求.19 1.2 需求分析.19 2.系统设计.20 2.1 概要设计.20 2.2 详细设计.20 3.软件开发.20 4.软件测试.20 5.特点与不足.21 5.1 技术特点.21 5.2 不足和改进的建议.21 6.过程和体会.21 6.1 遇到的主要问题和解决方法.21 6.2 课程设计的体会.21 7.源码和说明.21 7.1 文件清单及其功能说明.21 7.2 用户使用说明书.21 7.3 源代码.21 实验四.面向对象的整型队列编程.25 1.需求分析.25 1.1 题目要求.25 1.2 需求分析.25 2.系统设计.26 3.软件开发.26 4.软件测试.26 5.特点与
4、不足.26 5.1 技术特点.26 5.2 不足和改进的建议.26 6.过程和体会.26 6.1 遇到的主要问题和解决方法.26 实用标准文档 文案大全 6.2 课程设计的体会.27 7.源码和说明.27 7.1 文件清单及其功能说明.27 7.2 用户使用说明书.27 7.3 源代码.27 实验五.基于组合的整型队列编程.31 1.需求分析.31 1.1 题目要求.31 1.2 需求分析.31 2.系统设计.31 3.软件开发.32 4.软件测试.32 5.特点与不足.32 5.1 技术特点.32 5.2 不足和改进的建议.32 6.过程和体会.32 6.1 遇到的主要问题和解决方法.32
5、6.2 课程设计的体会.32 7.源码和说明.33 7.1 文件清单及其功能说明.33 7.2 用户使用说明书.33 7.3 源代码.33 实验六.基于继承的整型队列编程.37 1.需求分析.37 1.1 题目要求.37 1.2 需求分析.38 2.系统设计.38 3.软件开发.38 4.软件测试.38 5.特点与不足.38 5.1 技术特点.38 5.2 不足和改进的建议.38 6.过程和体会.39 6.1 遇到的主要问题和解决方法.39 6.2 课程设计的体会.39 实用标准文档 文案大全 7.源码和说明.39 7.1 文件清单及其功能说明.39 7.2 用户使用说明书.39 7.3 源代
6、码.39 实用标准文档 文案大全 实验一.面向过程的整型栈编程 1.需求分析 1.1 题目要求 整型栈是一种先进后出的存储结构,对其进行的操作通常包括判断栈是否为空、向栈顶添加一个整型元素、出栈等。整型栈类型及其操作函数采用非面向对象的纯 C 语言定义,请将完成上述操作的所有函数采用面向过程的方法编程,然后写一个 main 函数对栈的所有操作函数进行测试。struct STACK int *elems;/申请内存用于存放栈的元素 int max;/栈能存放的最大元素个数 int pos;/栈实际已有元素个数,栈空时pos=0;void initSTACK(STACK*const p,int m
7、);/初始化 p 指空栈:可存 m 个元素 void initSTACK(STACK*const p,const STACK&s);/用 s 初始化 p 指空栈 int size(const STACK*const p);/返回 p 指的栈的最大元素个数max int howMany(const STACK*const p);/返回 p 指的栈的实际元素个数 pos int getelem(const STACK*const p,int x);/取下标 x 处的栈元素 STACK*const push(STACK*const p,int e);/将 e 入栈,并返回 p STACK*const
8、 pop(STACK*const p,int&e);/出栈到 e,并返回 p STACK*const assign(STACK*const p,const STACK&s);/赋给 p 指栈,返回 p void print(const STACK*const p);/打印 p 指向的栈元素 void destroySTACK(STACK*const p);/销毁 p 指向的栈,释放 实用标准文档 文案大全 1.2 需求分析 本实验需要实现栈的功能的操作,如元素的进栈,连续进栈,出栈和连续出栈,所以需要设计两个栈,在完成初始化后直接在程序里给定栈内元素。2.系统设计 2.1 概要设计 函数结构图
9、见图 1.1 栈初始化栈返回max,pos取栈内元素入栈、出栈打印栈销毁栈图 1.1 总体流程图见图 1.2 实用标准文档 文案大全 开始初始化是否继续入栈是否继续出栈销毁栈结束YNYN 图 1.2 2.2 详细设计 void initSTACK(STACK*const p,int m)入口参数:int m 出口参数:无 功能:初始化栈,可存 m 个元素 void initSTACK(STACK*const p,const STACK&s)入口参数:const STACK&s 出口参数:无 功能:用 s 初始化 p 指空栈 int size(const STACK*const p)入口参数:无
10、 出口参数:int max 功能:返回 p 指的栈的最大元素个数 max int howMany(const STACK*const p)入口参数:无 出口参数:int pos 功能:返回 p 指的栈的实际元素个数 pos 实用标准文档 文案大全 int getelem(const STACK*const p,int x)入口参数:int x 出口参数:elemm 功能:取下标 x 处的栈元素 STACK*const push(STACK*const p,int e)入口参数:int e 出口参数:(*this)功能:将 e 入栈,并返回 p STACK*const pop(STACK*con
11、st p,int&e)入口参数:int&e 出口参数:(*this)功能:出栈到 e,并返回 p STACK*const assign(STACK*const p,const STACK&s)入口参数:STACK&s 出口参数:(*this)功能:赋 s 给 p 指栈,返回 p void print(const STACK*const p)入口参数:无 出口参数:无 功能:打印 p 指向的栈元素 void destroySTACK(STACK*const p)入口参数:出口参数:功能:销毁 p 指向的栈,释放 3.软件开发 在 Codeblocks 编译环境下,使用 C+语言编写。4.软件测试
12、 测试结果见图 1.3 实用标准文档 文案大全 图 1.3 5.特点与不足 5.1 技术特点 完成了实验的所有要求,没有错误的地方。5.2 不足和改进的建议 没有做人机交互界面,无法自由选择入栈的数据;同时注释较少,对于程序不了解的人可能需要花费更多时间去了解。6.过程和体会 6.1 遇到的主要问题和解决方法 输出结果数字与预计不同,检查后发现原因是变量初始值未设置。6.2 课程设计的体会 本次实验主要还是通过回顾C 语言中栈的知识完成在 C+上的编程,所以实用标准文档 文案大全 总体过程没有出现太大的问题;同时也对 const 变量有了进一步的认识。7.源码和说明 7.1 文件清单及其功能说
13、明 experiment1.cpp 源码 experiment1.exe 可执行文件。7.2 用户使用说明书 experiment1.cpp是程序的源码,可通过修改其中 main 函数中的变量来测试各个函数。7.3 源代码#include#include#include struct STACK int *elems;/申请内存用于存放栈的元素 int max;/栈能存放的最大元素个数 int pos;/栈实际已有元素个数,栈空时pos=0;void initSTACK(STACK*const p,int m);/初始化 p 指向的栈:最多 m 个元素 void initSTACK(STACK
14、*const p,const STACK&s);/用栈 s 初始化 p 指向的栈 int size(const STACK*const p);/返回 p 指向的栈的最大元素个数 max int howMany(const STACK*const p);/返回 p 指向的栈的实际元素个数 pos int getelem(const STACK*const p,int x);/取下标 x 处的栈元素 STACK*const push(STACK*const p,int e);/将 e 入栈,并返回 p STACK*const pop(STACK*const p,int&e);/出栈到 e,并返回
15、p 实用标准文档 文案大全 STACK*const assign(STACK*const p,const STACK&s);/赋 s 给 p 指的栈,并返回 p void print(const STACK*const p);/打印 p 指向的栈 void destroySTACK(STACK*const p);/销毁 p 指向的栈 int main(int argc,char*argv)STACK*s1=(STACK*)malloc(sizeof(STACK);STACK*s2=(STACK*)malloc(sizeof(STACK);initSTACK(s1,10);push(s1,1);
16、push(s1,2);push(push(s1,3),4);initSTACK(s2,*s1);print(s2);printf(栈 s1:n);print(s1);/assign(s2,*s1);printf(栈 s2:n);print(s2);int a,b,c;a=size(s1);printf(栈的最大元素个数是%dn,a);b=howMany(s1);printf(栈的实际元素个数是%dn,b);c=getelem(s1,3);printf(3 处栈元素是是%dn,c);int x,y,z;pop(s2,x);pop(pop(s2,y),z);printf(x=%d,y=%d,z=%
17、d n,x,y,z);destroySTACK(s2);destroySTACK(s1);实用标准文档 文案大全 getchar();return 0;void initSTACK(STACK*const p,int m)/初始化 p 指向的栈:最多 m个元素 p-elems=(int*)malloc(m*sizeof(int*);if(!p-elems)return;p-pos=0;p-max=m;int i;for(i=0;imax);i+)p-elemsi=0;void initSTACK(STACK*const p,const STACK&s)/用栈 s 初始化 p 指向的栈 p-el
18、ems=(int*)malloc(s.max)*sizeof(int);p-pos=s.pos;p-max=s.max;int i;for(i=0;ielemsi=s.elemsi;printf(%dn,p-elemsi);int size(const STACK*const p)/返回 p 指向的栈的最大元素个数 max return p-max;实用标准文档 文案大全 int howMany(const STACK*const p)/返回 p 指向的栈的实际元素个数 pos return p-pos;int getelem(const STACK*const p,int x)/取下标 x
19、处的栈元素 if(p=NULL)return NULL;else if(x(p-pos)printf(不存在元素n);else return p-elemsx;STACK*const push(STACK*const p,int e)/将 e 入栈,并返回 p if(p=NULL)return NULL;else if(p-pos)max)p-elemsp-pos=e;p-pos+;return p;实用标准文档 文案大全 else printf(栈满n);STACK*const pop(STACK*const p,int&e)/出栈到 e,并返回 p if(p=NULL)return NUL
20、L;else if(p-pos)=0)printf(栈为空n);else e=p-elems(p-pos)-1;(p-pos)-;return p;STACK*const assign(STACK*const p,const STACK&s)/赋 s 给 p 指的栈,并返回 p if(p=NULL|&s=NULL)return NULL;else free(p-elems);/free(p);/STACK*p=(STACK*)malloc(sizeof(STACK);实用标准文档 文案大全 initSTACK(p,s);return p;void print(const STACK*const
21、 p)/打印 p 指向的栈 int i;if(p=NULL)return;else if(p-pos=0)printf(栈为空n);else for(i=0;ipos);i+)printf(%d,p-elemsi);printf(n);void destroySTACK(STACK*const p)/销毁 p 指向的栈 free(p-elems);free(p);printf(栈已销毁n);实用标准文档 文案大全 实验二.面向对象的整型栈编程 1.需求分析 1.1 题目要求 整型栈是一种先进后出的存储结构,对其进行的操作通常包括判断栈是否为空、向栈顶添加一个整型元素、出栈等。整型栈类型及其操作
22、函数采用面向对象的 C+语言定义,请将完成上述操作的所有函数采用C+编程,然后写一个 main 函数对栈的所有操作函数进行测试。class STACK int *const elems;/申请内存用于存放栈的元素 const int max;/栈能存放的最大元素个数 int pos;/栈实际已有元素个数,栈空时pos=0;public:STACK(int m);/初始化栈:最多 m 个元素 STACK(const STACK&s);/用栈 s 拷贝初始化栈 int size()const;/返回栈的最大元素个数 max int howMany()const;/返回栈的实际元素个数 pos in
23、t getelem(int x)const;/取下标 x 处的栈元素 STACK&push(int e);/将 e 入栈,并返回栈 STACK&pop(int&e);/出栈到 e,并返回栈 STACK&assign(const STACK&s);/赋 s 给栈,并返回被赋值的栈 void print()const;/打印栈 STACK();/销毁栈;1.2 需求分析 采用面向对象的 C+语言定义整型栈,对其进行的操作通常包括判断栈是否为空、向栈顶添加一个整型元素、出栈等。实用标准文档 文案大全 2.系统设计 2.1 概要设计 首先需要定义一个类来实现栈,然后依次实现栈的各个功能,在主函数中给定
24、一个栈然后,然后通过函数调用实现栈的功能。2.2 详细设计 STACK(int m)功能:初始化栈:最多 m 个元素 返回值:无 STACK(const STACK&s)功能:用栈 s 拷贝初始化栈 返回值:无 int size()const 功能:返回栈的最大元素个数max 返回值:最大元素个数 max int howMany()const 功能:返回栈的实际元素个数pos 返回值:元素数目 pos int getelem(int x)const 功能:取下标 x 处的栈元素 返回值:下标为 x 的元素 STACK&push(int e)功能:将 e 入栈 返回值:栈的引用 STACK&po
25、p(int&e)功能:出栈到 e,并返回栈 返回值:栈的引用 实用标准文档 文案大全 STACK&assign(const STACK&s)功能:使用栈 s 给栈 p 赋值 返回值:栈的引用 void print()const 功能:打印栈 返回值:无 STACK()功能:销毁栈 返回值:无 3.软件开发 在 Codeblocks 编译环境下,使用 C+语言编写。4.软件测试 测试结果见图 2.1 图 2.1 5.特点与不足 5.1 技术特点 完成了初定目标,无其他特点。实用标准文档 文案大全 5.2 不足和改进的建议 人机交互需要进一步完善。6.过程和体会 6.1 遇到的主要问题和解决方法
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 面向 对象 程序设计 课程 实验 报告 材料 3150
限制150内