面向对象程序设计课程实验总结报告.docx

上传人:b****1 文档编号:1068946 上传时间:2022-10-16 格式:DOCX 页数:42 大小:149.22KB
下载 相关 举报
面向对象程序设计课程实验总结报告.docx_第1页
第1页 / 共42页
面向对象程序设计课程实验总结报告.docx_第2页
第2页 / 共42页
面向对象程序设计课程实验总结报告.docx_第3页
第3页 / 共42页
面向对象程序设计课程实验总结报告.docx_第4页
第4页 / 共42页
面向对象程序设计课程实验总结报告.docx_第5页
第5页 / 共42页
点击查看更多>>
下载资源
资源描述

面向对象程序设计课程实验总结报告.docx

《面向对象程序设计课程实验总结报告.docx》由会员分享,可在线阅读,更多相关《面向对象程序设计课程实验总结报告.docx(42页珍藏版)》请在冰豆网上搜索。

面向对象程序设计课程实验总结报告.docx

面向对象程序设计课程实验总结报告

舉申科按衣專

课程实验报告

课程名称:

面向对象程序设计

院系:

专业班级:

学号:

姓名:

指导教师:

实验一.面向过程的整型栈编程1

1.需求分析1

1.1题目要求1

1.2需求分析1

2.系统设计2

2.1概要设计2

2.2详细设计3

4.软件测试4

5.特点与不足4

5.1技术特点4

5.2不足和改进的建议5

6.过程和体会5

6.1遇到的主要问题和解决方法5

6.2课程设计的体会5

7.源码和说明5

7.1文件清单及其功能说明5

7.2用户使用说明书5

7.3源代码5

实验二.面向对象的整型栈编程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

7.源码和说明15

7.1文件清单及其功能说明15

7.2用户使用说明书15

7.3源代码15

实验三.基于算符重载的整型栈编程19

1.需求分析19

1.1题目要求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.特点与不足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

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

7.源码和说明39

7.1文件清单及其功能说明39

7.2用户使用说明书39

7.3源代码39

实验一.面向过程的整型栈编程

1.需求分析

1.1题目要求

整型栈是一种先进后出的存储结构,对其进行的操作通常包括判断栈是否为空、向栈顶添加一个整型元素、出栈等。

整型栈类型及其操作函数采用非面向对象的纯C语言定义,请将完成上述操作的所有函数采用面向过程的方法编程,然后写一个main函数对栈的所有操作函数进行测试。

structSTACK{

int

*elems;

//申请内存用于存放栈的兀素

int

max;

//栈能存放的最大兀素个数

int

pos;

//栈实际已有元素个数,栈空时pos=0;

};

voidinitSTACK(STACK*constp,intm);〃初始化p指空栈:

可存m个元素voidinitSTACK(STACK*constp,constSTACK&s);//用s初始化p指空栈intsize(constSTACK*constp);〃返回p指的栈的最大元素个数max

inthowMany(constSTACK*constp);〃返回p指的栈的实际元素个数posintgetelem(constSTACK*constp,intx);〃取下标x处的栈元素

STACK*constpush(STACK*constp,inte);〃将e入栈,并返回pSTACK*constpop(STACK*constp,int&e);//出栈到e,并返回p

STACK*constassign(STACK*constp,constSTACK&s);〃赋给p指栈,返回pvoidprint(constSTACK*constp);〃打印p指向的栈元素

voiddestroySTACK(STACK*constp);〃销毁p指向的栈,释放

1.2需求分析

本实验需要实现栈的功能的操作,如元素的进栈,连续进栈,出栈和连续出栈,所以需要设计两个栈,在完成初始化后直接在程序里给定栈内元素。

2.系统设计

2.1概要设计

函数结构图见图1.1

图1.1

总体流程图见图1.2

 

2.2详细设计

voidinitSTACK(STACK*constp,intm)

入口参数:

intm

出口参数:

功能:

初始化栈,可存m个元素

voidinitSTACK(STACK*constp,constSTACK&s)

入口参数:

constSTACK&s

出口参数:

功能:

用s初始化p指空栈

intsize(constSTACK*constp)

入口参数:

出口参数:

intmax

功能:

返回p指的栈的最大元素个数max

inthowMany(constSTACK*constp)

入口参数:

出口参数:

intpos

功能:

返回p指的栈的实际元素个数pos

intgetelem(constSTACK*constp,intx)

入口参数:

intx

出口参数:

elem[m]

功能:

取下标x处的栈元素

STACK*constpush(STACK*constp,inte)入口参数:

inte

出口参数:

(*this)

功能:

将e入栈,并返回p

STACK*constpop(STACK*constp,int&e)入口参数:

int&e出口参数:

(*this)

功能:

出栈到e,并返回p

STACK*constassign(STACK*constp,constSTACK&s)入口参数:

STACK&s

出口参数:

(*this)

功能:

赋s给p指栈,返回p

voidprint(constSTACK*constp)

入口参数:

出口参数:

功能:

打印p指向的栈元素

voiddestroySTACK(STACK*constp)

入口参数:

出口参数:

功能:

销毁p指向的栈,释放

3.软件开发

在Codeblocks编译环境下,使用C++语言编写

4.软件测试

测试结果见图1.3

图1.3

5.特点与不足

5.1技术特点

完成了实验的所有要求,没有错误的地方。

5.2不足和改进的建议

没有做人机交互界面,无法自由选择入栈的数据;同时注释较少,对于程序不了解的人可能需要花费更多时间去了解。

6.过程和体会

6.1遇到的主要问题和解决方法

输出结果数字与预计不同,检查后发现原因是变量初始值未设置。

6.2课程设计的体会

本次实验主要还是通过回顾C语言中栈的知识完成在C++上的编程,所以总体过程没有出现太大的问题;同时也对const变量有了进一步的认识。

7.源码和说明

7.1文件清单及其功能说明

experimentl.cpp源码

experiment1.exe可执行文件。

7.2用户使用说明书

experimentl.cpp是程序的源码,可通过修改其中main函数中的变量来测试各个函数。

7.3源代码

#include

#include

#include

structSTACK

{

int*elems;//申请内存用于存放栈的元素

intmax;//栈能存放的最大元素个数

intpos;//栈实际已有元素个数,栈空时pos=0;

};

voidinitSTACK(STACK*constp,intm);//初始化p指向的栈:

多m个元素

voidinitSTACK(STACK*constp,constSTACK&s);//用栈s初始化p指

向的栈

intsize(constSTACK*constp);

个数max

inthowMany(constSTACK*constp);个数pos

intgetelem(constSTACK*constp,intx);

//返回p指向的栈的最大兀素

//返回p指向的栈的头际兀素

//取下标x处的栈兀

STACK*constpush(STACK*constp,inte);

STACK*constpop(STACK*constp,int&e);

//将e入栈,并返回p

//出栈到e,并返回p

STACK*constassign(STACK*constp,constSTACK&s);//赋s给p指的

 

栈,并返回p

voidprint(constSTACK*constp);

voiddestroySTACK(STACK*constp);

//打印p指向的栈

//销毁p指向的栈

intmain(intargc,char*argv[])

{

STACK*s1=(STACK*)malloc(sizeof(STACK));

STACK*s2=(STACK*)malloc(sizeof(STACK));initSTACK(s1,10);

push(s1,1);

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);

inta,b,c;

a=size(sl);

printf("栈的最大元素个数是%d\n",a);

b=howMany(s1);

printf(”栈的实际元素个数是%d\n",b);

c=getelem(s1,3);

printf("3处栈元素是是%d\n",c);

intx,y,z;

pop(s2,x);

pop(pop(s2,y),z);

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 党团工作 > 入党转正申请

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1