顺序栈基本操作实验报告.doc

顺序栈基本操作实验报告.doc

ID:48017563

大小:134.00 KB

页数:11页

时间:2020-01-18

顺序栈基本操作实验报告.doc_第1页
顺序栈基本操作实验报告.doc_第2页
顺序栈基本操作实验报告.doc_第3页
顺序栈基本操作实验报告.doc_第4页
顺序栈基本操作实验报告.doc_第5页
资源描述:

《顺序栈基本操作实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、数据结构实验三课程数据结构实验名称顺序栈基本操作第页专业班级学号姓名实验日期:年月日评分一、实验目的1.熟悉并能实现栈的定义和基本操作。2.了解和掌握栈的应用。二、实验要求1.进行栈的基本操作时要注意栈"后进先出"的特性。2.编写完整程序完成下面的实验内容并上机运行。3.整理并上交实验报告。三、实验内容1.编写程序任意输入栈长度和栈中的元素值,构造一个顺序栈,对其进行清空、销毁、入栈、出栈以及取栈顶元素操作。2.编写程序实现表达式求值,即验证某算术表达式的正确性,若正确,则计算该算术表达式的值。主要功能描述如下:

2、(1)从键盘上输入表达式。(2)分析该表达式是否合法:·a)是数字,则判断该数字的合法性。若合法,则压入数据到堆栈中。·b)是规定的运算符,则根据规则进行处理。在处理过程中,将计算该表达式的值。·c)若是其它字符,则返回错误信息。(3)若上述处理过程中没有发现错误,则认为该表达式合法,并打印处理结果。程序中应主要包含下面几个功能函数:·lvoidinitstack():初始化堆栈·lintMake_str():语法检查并计算·lintpush_operate(intoperate):将操作码压入堆栈·lintpu

3、sh_num(doublenum):将操作数压入堆栈·lintprocede(intoperate):处理操作码·lintchange_opnd(intoperate):将字符型操作码转换成优先级·lintpush_opnd(intoperate):将操作码压入堆栈·lintpop_opnd():将操作码弹出堆栈·lintcaculate(intcur_opnd):简单计算+,-,*,/·ldoublepop_num():弹出操作数四、实验步骤(描述实验步骤及中间的结果或现象。在实验中做了什么事情,怎么做的,发生

4、的现象和中间结果)第一题:#includeusingnamespacestd;#defineSTACK_INIT_SIZE100//存储空间初始分配量#defineSTACKINCREMENT10//存储空间分配增量#defineOVERFLOW-1#defineOK1#defineNO-1#defineNULL0typedefintStatus;typedefcharSElemType;typedefstruct{SElemType*base;//在栈构造之前和销毁之后,base的值为NUL

5、LSElemType*top;//栈顶指针intstacksize;//当前已分配的存储空间,以元素为单位}SqStack;StatusInitstack(SqStack&S)//构造一个空栈S{S.base=(SElemType*)malloc(STACK_INIT_SIZE*sizeof(SElemType));if(!S.base)exit(OVERFLOW);S.top=S.base;S.stacksize=STACK_INIT_SIZE;returnOK;}//InitStackStatusStackE

6、mpty(SqStack&S){if(S.base==S.top)returnOK;elsereturnNO;}StatusClearStack(SqStack&S)//把S置为空{if(S.base=S.top);returnOK;}StatusDsetroyStack(SqStack&S)//销毁栈S{S.base=NULL;returnOK;}StatusPush(SqStack&S,SElemTypee)//插入元素e为新的栈顶元素{if(S.top-S.base>=S.stacksize){S.base

7、=(SElemType*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(SElemType));if(!S.base)//存储分配失败exit(OVERFLOW);S.top=S.base+S.stacksize;S.stacksize+=STACKINCREMENT;}*S.top++=e;returnOK;}//PushStatusPop(SqStack&S,SElemType&c)//若栈不空,则删除S的栈顶元素,用c返回其值,并返回OK;否则返回ER

8、ROR{if(S.top==S.base)returnNO;c=*--S.top;returnOK;}//PopStatusGetTop(SqStack&S,SElemType&e){if(S.top==S.base)returnNO;e=*(S.top-1);returnOK;}//GetTopintmain(){SqStackS;Initstack(S);cout<<

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。