下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、课程实验报课程名称:面向对象程序设计院系:专业班级:学号:姓名:指导教师:目录实验一 .面向过程的整型栈编程 01. 需求分析 01.1 题目要求 01.2 需求分析 02. 系统设计 12.1 概要设计 12.2 详细设计 24. 软件测试 35. 特点与不足 35.1 技术特点 35.2 不足和改进的建议 46. 过程和体会 46.1 遇到的主要问题和解决方法 46.2 课程设计的体会 47. 源码和说明 47.1 文件清单及其功能说明 47.2 用户使用说明书 47.3 源代码 4实验二 .面向对象的整型栈编程 111. 需求分析 111.1 题目要求 111.2 需求分析 112. 系
2、统设计 122.1 概要设计 122.2 详细设计 123. 软件开发 134. 软件测试 135. 特点与不足 135.1 技术特点 135.2 不足和改进的建议 146. 过程和体会 147. 源码和说明 147.1 文件清单及其功能说明 147.2 用户使用说明书 147.3 源代码 14实验三 .基于算符重载的整型栈编程 181. 需求分析 181.1 题目要求 181.2 需求分析 182. 系统设计 192.1 概要设计 192.2 详细设计 193. 软件开发 194. 软件测试 195. 特点与不足 205.1 技术特点 205.2 不足和改进的建议 206. 过程和体会 20
3、6.1 遇到的主要问题和解决方法 206.2 课程设计的体会 207. 源码和说明 207.1 文件清单及其功能说明 207.2 用户使用说明书 207.3 源代码 20实验四 . 面向对象的整型队列编程 241. 需求分析 241.1 题目要求 241.2 需求分析 242. 系统设计 253. 软件开发 254. 软件测试 255. 特点与不足 255.1 技术特点 255.2 不足和改进的建议 256. 过程和体会 256.1 遇到的主要问题和解决方法 256.2 课程设计的体会 267. 源码和说明 267.1 文件清单及其功能说明 267.2 用户使用说明书 267.3 源代码 26
4、实验五 . 基于组合的整型队列编程 301. 需求分析 301.1 题目要求 301.2 需求分析 302. 系统设计 303. 软件开发 314. 软件测试 315. 特点与不足 315.1 技术特点 315.2 不足和改进的建议 316. 过程和体会 316.1 遇到的主要问题和解决方法 316.2 课程设计的体会 317. 源码和说明 327.1 文件清单及其功能说明 327.2 用户使用说明书 327.3 源代码 32实验六 . 基于继承的整型队列编程 361.需求分析 361.1 题目要求 361.2 需求分析 372.系统设计 373. 软件开发 374. 软件测试 375. 特点
5、与不足 375.1 技术特点 375.2 不足和改进的建议 376. 过程和体会 387. 源码和说明 387.1 文件清单及其功能说明 387.2 用户使用说明书 387.3 源代码 38实验一 . 面向过程的整型栈编程1. 需求分析1.1 题目要求整型栈是一种先进后出的存储结构,对其进行的操作通常包括判断栈是否 为空、向栈顶添加一个整型元素、出栈等。整型栈类型及其操作函数采用非面 向对象的纯 C 语言定义,请将完成上述操作的所有函数采用面向过程的方法编 程, 然后写一个 main 函数对栈的所有操作函数进行测试。struct STACKint*elems;/申请内存用于存放栈的元素intm
6、ax;/栈能存放的最大元素个数intpos;/栈实际已有元素个数,栈空时 pos=0;void initSTACK(STACK *const p, int m);/ 初始化 p 指空栈:可存 m 个元素 void initSTACK(STACK *const p, const STACK&s); / 用 s 初始化 p 指空栈 int size (const STACK *const p);/返回 p 指的栈的最大元素个数 maxint howMany (const STACK *const p); 返回p指的栈的实际元素个数 pos int getelem (const STACK
7、*const p, int x);/取下标 x 处的栈元素STACK *const push(STACK *const p, int e); 将 e入栈,并返回 pSTACK *const pop(STACK *const p, int &e); /出栈到 e,并返回 pSTACK *const assig n(STACK*co nst p, con st STACK&s); 赋给 p 指栈,返回 p void print(const STACK*const p);/打印 p 指向的栈元素void destroySTACK(STACK*const p);/销毁 p 指向的栈,释
8、放1.2 需求分析本实验需要实现栈的功能的操作,如元素的进栈,连续进栈,出栈和连续 出栈,所以需要设计两个栈,在完成初始化后直接在程序里给定栈内元素。2. 系统设计2.1概要设计函数结构图见图1.1销毁栈图1.1初始化栈总体流程图见图1.2YY2.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
9、size (const STACK *const p) 入口参数:无 出口参数: 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) 功
10、能:将 e 入栈,并返回 p STACK *const pop(STACK *const 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)入口参数
11、:出口参数:功能:销毁p指向的栈,释放3. 软件开发在Codeblocks编译环境下,使用 C+语言编写4. 软件测试测试结果见图1.3图1.35. 特点与不足5.1技术特点完成了实验的所有要求,没有错误的地方。5.2 不足和改进的建议没有做人机交互界面,无法自由选择入栈的数据;同时注释较少,对于程序不了解的人可能需要花费更多时间去了解。6. 过程和体会6.1 遇到的主要问题和解决方法输出结果数字与预计不同,检查后发现原因是变量初始值未设置。6.2 课程设计的体会本次实验主要还是通过回顾C语言中栈的知识完成在C+上的编程,所以 总体过程没有出现太大的问题;同时也对const变量有了进一步的认识
12、。7. 源码和说明7.1 文件清单及其功能说明experime ntl.cpp 源码 experime nt1.exe 可执行文件。7.2 用户使用说明书experimentl.cpp是程序的源码,可通过修改其中main函数中的变量来测试 各个函数。7.3 源代码#include<stdio.h>#include<malloc.h>#include<stdlib.h>struct STACKint *elems; / int max;int pos;申请内存用于存放栈的元素/ 栈能存放的最大元素个数/ 栈实际已有元素个数,栈空时 pos=0;4;void i
13、nitSTACK(STACK *const p, int m);/ 初始化 p指向的栈:最多m个元素void initSTACK(STACK *const p, const STACK&s); /用栈 s 初始化 p 指向的栈int size (const STACK *con st p);个数maxint howMa ny (co nst STACK *co nst p); 个数posint getelem (const STACK *const p, int x);素/返回p指向的栈的最大兀素/返回p指向的栈的头际兀素/取下标x处的栈兀STACK *const push(STACK
14、 *const p, int e);STACK *con st pop(STACK *con st p, i nt &e);/将e入栈,并返回p/出栈到e,并返回pSTACK *const assig n(STACK*co nst p, con st STACK&s); /赋 s 给 p 指的栈,并返回pvoid print(const STACK*const p);void destroySTACK(STACK*co nst p);/打印p指向的栈/销毁p指向的栈int main (i nt argc, char* argv)STACK *s1 = (STACK *)mall
15、oc(sizeof(STACK);STACK *s2 = (STACK *)malloc(sizeof(STACK); in itSTACK(s1,10);push(s1,1);push(s1,2); push(push(s1,3),4); ini tSTACK(s2,*s1);prin t(s2);printf("栈 s1:n");prin t(s1);/assig n(s2,*s1);printf("栈 s2:n");prin t(s2);int a,b,c; a = size(s1); printf(" 栈的最大元素个数是 %dn&quo
16、t;,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= %d n",x,y,z); destroySTACK(s2);destroySTACK(s1); getchar();return 0;void initSTACK(STACK *const p, int m) /初始化 p
17、指向的栈:最多 m个元素p->elems = (int*)malloc(m*sizeof(int*); if(!p->elems)return;p->pos = 0; p->max = m;int i; for(i=0;i<(p->max);i+) p->elemsi = 0;void initSTACK(STACK *const p, const STACK&s) /用栈 s 初始化 p 指向的栈p->elems = (int*)malloc(s.max)*sizeof(int); p->pos = s.pos;p->max
18、 = s.max;int i;for(i=0;i<(s.pos);i+)p->elemsi=s.elemsi;prin tf("%dn",p->elemsi);int size (const STACK *con st p)个数maxreturn p->max;int howMa ny (const STACK *co nst p) 个数posretur n p->pos;/返回p指向的栈的最大元素/返回p指向的栈的实际元素int getelem (const STACK *const p, i nt x) 素if(p=NULL)return
19、NULL;elseif(x>(p->pos) printf("不存在元素n");elsereturn p->elemsx;/取下标x处的栈元/ 将 e 入栈,并返回 p/出栈到e,并返回pSTACK *const push(STACK *const p, int e) if(p=NULL) return NULL; else if(p->pos)<=(p->max) p->elemsp->pos=e; p->pos+;return p;elseprintf("栈满 n");STACK *const p
20、op(STACK *const p, int &e) if(p=NULL)return NULL;elseif(p->pos)=0)printf(" 栈为空 n");elsee=p->elems(p->pos)-1;(p->pos)-;return p;STACK *const assig n(STACK*co nst p, con st STACK&s) / 赋 s 给 p 指的 栈,并返回pif(p=NULL | & s=NULL)return NULL;elsefree(p->elems);/free(p);/ST
21、ACK *p = (STACK *)malloc(sizeof(STACK);ini tSTACK(p,s);return p;void print(const STACK*const p)/ 打印 p指向的栈int i;if(p = NULL)return;else if(p->pos = 0)prin tf("栈为空 n");elsefor(i=0;i<(p->pos);i+)prin tf("%d ",p->elemsi);printf("n");void destroySTACK(STACK*const
22、 p)/ 销毁 p 指向的栈free(p->elems);free(p);printf(" 栈已销毁 n");实验二.面向对象的整型栈编程1. 需求分析1.1题目要求class STACKint *const elems; / const int max;int pos;public:STACK(i nt m);整型栈是一种先进后出的存储结构,对其进行的操作通常包括判断栈是否 为空、向栈顶添加一个整型元素、出栈等。整型栈类型及其操作函数采用面向 对象的C+语言定义,请将完成上述操作的所有函数米用 C+S程,然后写 个main函数对栈的所有操作函数进行测试。申请内存用于
23、存放栈的元素/栈能存放的最大元素个数/栈实际已有元素个数,栈空时pos=0;/初始化栈:最多m个元素STACK(const STACK&s); /用栈s拷贝初始化栈int size ( ) con st;/返回栈的最大元素个数 maxint howMa ny ( ) con st;/返回栈的实际元素个数 posint getelem (int x) con st;/ 取下标 x 处的栈元素STACK& push(int e);/将e入栈,并返回栈STACK& pop(int &e);/出栈到e,并返回栈STACK& assign(const STACK&
24、amp;s); /赋s给栈,并返回被赋值的栈 void prin t( ) con st;/ 打印栈STACK( );/ 销毁栈;1.2需求分析采用面向对象的C+语言定义整型栈,对其进行的操作通常包括判断栈是 否为空、向栈顶添加一个整型元素、出栈等。2. 系统设计2.1 概要设计首先需要定义一个类来实现栈,然后依次实现栈的各个功能,在主函数中给定一个栈然后,然后通过函数调用实现栈的功能。2.2 详细设计STACK(int m) 功能:初始化栈:最多 m 个元素返回值:无STACK(const STACK&s)功能:用栈 s 拷贝初始化栈返回值:无int size ( ) const 功
25、能:返回栈的最大元素个数 max 返回值:最大元素个数 maxint howMany ( ) const 功能:返回栈的实际元素个数 pos 返回值:元素数目 posint getelem (int x) const功能:取下标 x 处的栈元素返回值:下标为 x 的元素STACK& push(int e)功能:将 e 入栈 返回值:栈的引用STACK& pop(int &e)功能:出栈到e,并返回栈返回值:栈的引用STACK & assig n(co nst STACK&s)功能:使用栈s给栈p赋值 返回值:栈的引用void prin t( ) cons
26、t功能:打印栈 返回值:无STACK()功能:销毁栈返回值:无3. 软件开发在Codeblocks编译环境下,使用 C+语言编写4. 软件测试测试结果见图2.1图2.15. 特点与不足5.1技术特点完成了初定目标,无其他特点。5.2 不足和改进的建议人机交互需要进一步完善。6. 过程和体会6.1 遇到的主要问题和解决方法由于第一次使用C+面向对象编写程序,开始不明白对象的生成及使用。 在和同学老师的沟通和交流中,慢慢学会了编程的方法。6.2 课程设计的体会C+语言与C语言有很多相通的地方,所以其中的某些原理和方法可以互 相借鉴,这样就减少了在理解上的难度。7. 源码和说明7.1 文件清单及其功
27、能说明experime nt2.cpp 源码 experime nt2.exe可执行文件7.2 用户使用说明书experiment2.cpp是程序的源码,可通过修改其中main函数中的变量来测试 各个函数。7.3 源代码#include <iostream>#include <string> using namespace std;class STACKint *constconst intelems;/申请内存用于存放栈的元素max; /栈能存放的最大元素个数int pos;/栈实际已有元素个数,栈空时 pos=0;public:STACK(int m);/初始化栈:
28、最多m 个元素STACK(const STACK&s); /用栈s拷贝初始化栈 int size ( ) con st; 返回栈的最大元素个数 max int howMa ny ( ) const; /返回栈的实际元素个数 pos int getelem (int x) con st; 取下标x处的栈元素 STACK& push(int e);/将e入栈,并返回栈STACK& pop(int &e);/出栈到e并返回栈STACK& assign(const STACK&s); /赋s给栈,并返回被赋值的栈 void print( ) con st
29、;/ 打印栈STACK( );/ 销毁栈;STACK:STACK(int m):elems(new intm),max(m),pos(0) STACK:STACK(co nst STACK&s):elems( newin ts.size(),max(s.size(),pos(s.howMa ny()for(i nt i=0;i<pos;i+)elemsi=s.getelem(i);cout«"复制构造成功"<<endl;int STACK:size() con streturn max;int STACK:howMa ny() const
30、return pos;int STACK:getelem (int x) con streturn elemsx;STACK & STACK:push(i nt e)if(posvmax)elemspos=e;pos+;else cout<<"fulln"return *this;STACK& STACK:pop(int &e)if(pos=0)cout<<"empty stack"return *this;pos-;e = elemspos;coutvv"出栈成功"return *th
31、is;STACK& STACK:assign(const STACK&s) int i;delete elems;/elems = new int s.size();/max = s.size();pos = s.howMany(); for(i=0;i<s.howMany();i+) elemsi = s.getelem(i); return *this;void STACK:print( ) constint i;coutvv"栈的元素为:"for(i=0;i<pos;i+)coutvvelemsivv" " coutvv
32、endl;STACK:STACK()delete elems;/ elems= 0;/ max = 0;pos = 0;cout«"析构完成"int mai n()STACK s(7);s.push(5);s.push(7);s.push(9);s.push(11);s.pri nt();int i;s.pop(i);cout«"出栈元素"vvivvendl;STACK p(s);cout«"容量"<vp.size()v<e ndl; cout«"当前元素数目"v
33、vp.howMany();实验三 . 基于算符重载的整型栈编程1. 需求分析1.1 题目要求virtual int size ( ) const;virtual operator int ( ) const;virtual int operator (int x) const;/ virtual STACK& operator<<(int e); virtual STACK& operator>>(int &e);/ 返回栈的最大元素个数 max / 返回栈的实际元素个数 pos 取下标 x 处的栈元素/ 将 e 入栈, 并返回栈/ 出栈到 e,
34、 并返回栈整型栈是一种先进后出的存储结构,对其进行的操作通常包括判断栈是否 为空、向栈顶添加一个整型元素、出栈等。整型栈类型及其操作函数采用面向 对象的C+语言定义,请将完成上述操作的所有函数米用C+编程,然后写个 main 函数对栈的所有操作函数进行测试。class STACKint *const elems; / const int max;int pos;public:申请内存用于存放栈的元素/ 栈能存放的最大元素个数/ 栈实际已有元素个数,栈空时 pos=0;STACK(int m);/初始化栈:最多m个元素STACK(const STACK&s);/ 用栈 s 拷贝初始化栈v
35、irtual STACK& operator=(const STACK&s);/ 赋 s 给栈, 并返回被赋 值的栈/ 打印栈/ 销毁栈virtual void print( ) const;virtual STACK( );1.2 需求分析采用面向对象的C+语言定义,构建整型栈并对其进行判断栈是否为空、 向栈顶添加一个整型元素、出栈等操作。2. 系统设计2.1概要设计首先需要定义一个类来实现栈,然后依次实现栈的各个功能,在主函数中 给定一个栈然后,然后通过函数调用实现栈的功能。2.2详细设计初始化定义一个类,分配一个数组空间来存储栈内元素信息,然后初始化为0;实现入栈则需要将
36、入栈元素e放入栈内,采用了先判断栈的最大容量够 不够的问题,如果不够重新分配空间,并且让e入栈,将当前元素pos加一; 然后返回栈结构。实现出栈操作,首先判断是不是空,若空直接返回,不空则需将栈顶的元 素赋给一个变量然后将当前元素 pos减一;返回栈结构。实现栈的赋给即需要将si栈内的元素依次赋给s2栈的,当前元素也需一 致并且返回新的栈结构。3. 软件开发在Codeblocks编译环境下,使用 C+语言编写。4. 软件测试测试结果见图3.1图3.15. 特点与不足5.1 技术特点使用了符号重载,在一定程度上简化了函数。5.2 不足和改进的建议 在使用符号重载时需要特别注意,防止与其他操作符混
37、淆。6. 过程和体会6.1 遇到的主要问题和解决方法对于符号重载,刚开始不会调用函数,之后通过查阅书籍,明白了重载的 含义。6.2 课程设计的体会本次实验以实验二为基础,通过使用符号重载来更简单的实现实验目的。7. 源码和说明7.1 文件清单及其功能说明experime nt3.cpp 源码experime nt3.exe 可执行文件。7.2 用户使用说明书experiment3.cpp是程序的源码,可通过修改其中main函数中的变量来测试 各个函数。7.3 源代码#include <iostream>#include <string>using namespace s
38、td;class STACKint *const elems;/申请内存用于存放栈的元素const int max; 栈能存放的最大元素个数int pos;/栈实际已有元素个数,栈空时 pos=0;public:STACK(int m);/初始化栈:最多m个元素STACK(const STACK&s);/用栈s拷贝初始化栈virtual int size ( ) const;返回栈的最大元素个数 maxvirtual operator int () con st;返回栈的实际元素个数 posvirtual in t operator (i nt x) con st;取下标 x 处的栈元
39、素virtual STACK& operator«(int e);/将 e 入栈并返回栈virtual STACK& operator»(int &e); /出栈到 e,并返回栈 virtual STACK& operator=(const STACK&s); / 赋 s 给栈,并返回被赋值的栈 virtual void prin t( ) con st;/ 打印栈virtual STACK( );/ 销毁栈;STACK:STACK(int m):elems(new intm),max(m),pos(0) STACK:STACK(co
40、 nst STACK&s):elems( newin ts.max),max(s.max),pos(s.pos)for(i nt i=0;i<pos;i+)elemsi=s.elemsi;int STACK:size ( ) con streturn max;STACK:operator int () con streturn pos;int STACK:operator (int x) con streturn elemsx;STACK & STACK:operator<<(i nt e)if(pos>max)coutvv"栈满"e
41、lse*(elems+pos)=e;pos+;return (*this);STACK& STACK:operator>>(int &e)if(pos=0)cout«"栈空"elsee=*(elems+pos-1);pos-;return (*this);STACK& STACK:operator=(const STACK&s)delete elems;*(int*)&elems = new ints.max;*(int*)&max = s.max; for(pos=0;pos<s.pos;pos+
42、) elemspos = s.elemspos;return *this;void STACK:print( ) constfor(int i=0;i<pos;i+) cout<<elemsi<<"n"STACK:STACK( )delete elems;if(elems=0)cout«"销毁失败"<<endl;elsecoutvv"销毁成功"<<endl;int mai n()STACK i(5),j(8); i<<1<<3<<6&l
43、t;<9;int k;i»k;cout<<kvv"n"i. pri nt();j=i;j.pri nt(); j<<1<<2<<3<<4;cout«e ndl«(i nt)j;实验四.面向对象的整型队列编程1. 需求分析1.1题目要求整型队列是一种先进先出的存储结构,对其进行的操作通常包括判断队列 是否为空、向队列顶添加一个整型元素、出队列等。整型队列类型及其操作函 数米用面向对象的C+语言定义,请将完成上述操作的所有函数米用C+®程,class QUEUEint *c
44、onst elems; / const int max;int head, tail;时 head=tail=O然后写一个main函数对队列的所有操作函数进行测试。申请内存用于存放队列的元素/队列能存放的最大元素个数/队列头和尾,队列空时head=tail;初始public:QUEUE(int m);/初始化队列:最多 m个元素QUEUE(const QUEUE&s);/用队列s拷贝初始化队列virtual operator int ( ) con st;/返回队列的实际元素个数virtual QUEUE& operator«(i nt e)volatile;返回队列
45、virtual QUEUE& operator>>(int &e)volatile;返回队列/将e入队列,并/出队列到e,并virtual QUEUE & operator=(co nst QUEUE&s); /赋s给队列,并返回被赋值的队列virtual void prin t( ) con st;/打印队列virtual QUEUE();/销毁队列;1.2需求分析本题目用数组实现队列,需要预知需要空间的大小,会造成空间浪费或不够用;插入或删除不需要动态分配或删除内存,耗时很小;支持随机存取。2. 系统设计定义一个类,分配一个数组空间来存储栈内元素
46、信息,类中分别定义两个 int元素表示队列的头和尾,入栈的时候,头加一;出栈的时候,尾加一。3. 软件开发在Codeblocks编译环境下,使用 C+语言编写4. 软件测试测试结果见图4.1图4.15. 特点与不足5.1技术特点通过创建队列类QUEUE完成了队列的构造析构等诸多功能;同时再次运 用重载操作符方便了入队出队等操作的完成。5.2不足和改进的建议队列一旦生成则无法改变。6. 过程和体会6.1遇到的主要问题和解决方法如何构建一个循环队列,解决方法利用求余的方法,当头结点大于最大元 素的时候,除以最大元素求余,重新的得到头结点。6.2 课程设计的体会本次实验使用面向对象的方法来编写一个队
47、列,让我对队列的构建以及对其进行一些列的操作有了更进一步的了解。与前几次栈的实验相比,难度有所 增加,但更锻炼了个人能力。7. 源码和说明7.1 文件清单及其功能说明experime nt4.cpp 源码experime nt4.exe 可执行文件。7.2 用户使用说明书experiment4.cpp是程序的源码,可通过修改其中main函数中的变量来测试各个函数。7.3 源代码#include <iostream>#include <string>using namespace std;class QUEUEint *const elems;/申请内存用于存放队列的元素
48、const int max; /队列能存放的最大元素个数int head, tail;/队列头和尾,队列空时 head=tail初始时head=tail=0public:QUEUE(int m);/初始化队列:最多 m 个元素QUEUE(const QUEUE&s);/用队列s拷贝初始化队列virtual operator int ( ) const;/返回队列的实际元素个数virtual QUEUE& operator<<(int e);/将 e 入队列 ,并返回队列virtual QUEUE& operator»(int &e); /
49、出队列到 e并返回队列 virtual QUEUE& operator=(const QUEUE&s); / 赋 s给队列,并返回被赋值的 队列virtual void print( ) const;/打印队列virtual QUEUE( );/销毁队列;QUEUE:QUEUE(int m):elems(new intm),max(m),head(O),tail(O)QUEUE:QUEUE(co nst QUEUE&s):elems( newin ts.max),max(s.max),head(s.head),tail(s.tail)for(int i=head;i&l
50、t;tail;i+)elemsi=s.elemsi;QUEUE:operator int () con stif(tail>=head)return (tail-head);retur n (max-head+tail);QUEUE & QUEUE:operator«(i nt e)if(tail+1)%max=head)coutvv"队列满 n"elseelemstail=e;tail+;return (*this);QUEUE & QUEUE:operator»(i nt & e)if(head=tail)coutvv&
51、quot;队列空 n"elsee=elemshead;head=(head+)%max;return(*this);QUEUE& QUEUE:operator=(const QUEUE&s) delete elems;*(int*)&elems = new ints.max;*(int*)&max = s.max;head = s.head;tail = s.tail;for(int i=head;i<tail;i+) elemsi=s.elemsi;cout«"赋值成功n"return *this;void QUE
52、UE:print( ) constif(head=tail)cout<<"Emptyn" cout«"队列元素为:"if(head<tail)for(int i=head;i<tail;i+) cout<<elemsi<<"t"elsefor(int i=head;i<max+1;i+) cout<<elemsi<<"t"for(int i=0;i<tail;i+)cout<<elemsi<<&qu
53、ot;t" cout<<"n"QUEUE:QUEUE( )delete elems;*(int*)&elems = 0;*(int*)&max =0;head = tail =0;int mai n()QUEUE q(5);q<<2<<5<<8;cout«"元素数目"<<(int)q«endl;QUEUE p(q);p.pri nt();int i;q»i;cout«"出队元素"<<i<<
54、;endl;q.pri nt();实验五 . 基于组合的整型队列编程1. 需求分析1.1 题目要求整型队列是一种先进先出的存储结构,对其进行的操作通常包括判断队列 是否为空、向队列顶添加一个整型元素、出队列等。整型队列类型及其操作函 数米用面向对象的C+语言定义,请将完成上述操作的所有函数米用C+编程,然后写一个 main 函数对队列的所有操作函数进行测试。注意,请用实验三的 SATCK&合形成新的类QUEUE请说明如果删掉virtual有什么不同。class QUEUESTACK s1, s2;public:QUEUE(int m);/初始化队列:每个栈最多 m个元素QUEUE(co
55、nst QUEUE&s);/用队列s拷贝初始化队列virtual operator int ( ) const;/ 返回队列的实际元素个数virtual QUEUE& operator«(int e);/ 将 e入队列,并返回队列virtual QUEUE& operator»(int &e);/ 出队列到 e,并返回队列virtual QUEUE& operator=(const QUEUE&s); /赋 s 给队列,并返回被赋值的队列virtual void print( ) const;/ 打印队列virtual QUEUE( );/ 销毁队列;1.2 需求分析采用面向对象的C+语言定义,构建整型队列并对其进行的操作通常包括 判断队列是否为空、向队列顶添加一个整型元素、出队列等,再写一个 main 函数对队列的所有操作函数进行测试。 。2. 系统设计用两个栈实现队列,先判栈 S2是否为空,如果为空,对S1进行入栈操作, 如果
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年黄埔海关国际旅行卫生保健中心公开招聘非占编聘用人员的备考题库带答案详解
- 2026年衡阳市第一人民医院妇产科医师招聘备考题库及1套参考答案详解
- 2026年智链电磁材料(山东)有限公司招聘备考题库有答案详解
- 2026年泸州市部分企事业单位人才引进88人备考题库及参考答案详解
- 2026年温州市人民医院(温州市妇幼保健院)劳务派遣人员招聘备考题库(五)及一套参考答案详解
- 养老院入住老人纠纷调解与处理制度
- 2026年首都医学科学创新中心孙少聪实验室招聘生物备考题库学分析科研助理及完整答案详解一套
- 2026年黄石市消防救援支队招聘政府专职消防员18人备考题库及参考答案详解
- 企业内部保密协议签订制度
- 2025年检疫机构传染病防控操作手册
- 混凝土生产过程监控方案
- 2026北京市中央广播电视总台招聘124人参考题库附答案
- 十五五规划纲要解读:循环经济模式推广
- 2023第十四届希望杯五年级100题
- 活动赞助邀请函 赞助费邀请函(7篇)
- 2023-2024学年浙江省诸暨市小学数学六年级上册期末评估测试题
- 重庆市园林工程师园林工程施工与技术知识要点
- YS/T 668-2008铜及铜合金理化检测取样方法
- GB/T 25155-2010平板硫化机
- 医务人员文明服务与礼仪培训课件
- 循环流化床锅炉运行经济性分析(一)
评论
0/150
提交评论