数据结构栈的应用(8页).doc

上传人:1595****071 文档编号:36762431 上传时间:2022-08-28 格式:DOC 页数:8 大小:181KB
返回 下载 相关 举报
数据结构栈的应用(8页).doc_第1页
第1页 / 共8页
数据结构栈的应用(8页).doc_第2页
第2页 / 共8页
点击查看更多>>
资源描述

《数据结构栈的应用(8页).doc》由会员分享,可在线阅读,更多相关《数据结构栈的应用(8页).doc(8页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、-数据结构栈的应用-第 8 页数据结构实验报告实验序号:4 实验项目名称:栈的操作学号1407022228姓名王元专业、班网络工程2班实验地点1-314指导教师林仙丽实验时间一、实验目的及要求1. 熟悉栈的基本概念;2. 掌握栈的顺序存储结构;3掌握栈的应用。二、实验设备(环境)及要求微型计算机;windows 操作系统;Microsoft Visual Studio 6.0集成开发环境。三、实验内容与步骤1.栈的顺序表表示和实现的如下:#include #define MaxSize 100using namespace std;typedef int ElemType;typedef st

2、ructElemType dataMaxSize;int top;SqStack;void InitStack(SqStack *st) /初始化栈st-top=-1;int StackEmpty(SqStack *st) /判断栈为空return (st-top=-1);void Push(SqStack *st,ElemType x) /元素进栈if(st-top=MaxSize-1)printf(栈上溢出!n);elsest-top+; /移动栈顶位置st-datast-top=x; /元素进栈void Pop(SqStack *st,ElemType *e) /出栈if(st-top=

3、-1)printf(栈下溢出n);else*e=st-datast-top; /元素出栈st-top-; /移动栈顶位置int main()SqStack L;SqStack *st=&L;ElemType e;int i;InitStack(st);for(i=1;i10;+i)Push(st,i);printf(入栈元素是:%dn,i);for(i=1;i10;+i)Pop(st,e);printf(出栈元素是:%dn,e);return 0; 改写以上程序,实现功能如下:调用栈操作函数实现判别一个算术表达式中的圆括号和方括号配对是否正确匹配。2.C/C+的库函数中已经实现了栈,实例如下:

4、#include /引入栈using namespace std;int main()int a;stacks;scanf(%d,&a);s.push(a); /入栈printf(%dn,s.top(); /取得栈顶元素输出s.pop(); /出栈return 0; 请根据以上程序,设计算法如下:判别一个算术表达式中的圆括号配对是否正确。四、 分析与讨论1.2.对上机实践结果进行分析,上机的心得体会。五、教师评语签名:日期:成绩附源程序清单:1.#include #define MaxSize 100using namespace std;typedef char ElemType;typed

5、ef structElemType dataMaxSize;int top;SqStack;void InitStack(SqStack *st) /初始化栈st-top=-1;int StackEmpty(SqStack *st) /判断栈为空return (st-top=-1);void Push(SqStack *st,ElemType x) /元素进栈if(st-top=MaxSize-1)printf(栈上溢出!n);elsest-top+; /移动栈顶位置st-datast-top=x; /元素进栈void Pop(SqStack *st,ElemType *e) /出栈if(st

6、-top=-1)printf(栈下溢出n);else*e=st-datast-top; /元素出栈st-top-; /移动栈顶位置int main()SqStack L;SqStack *st=&L;ElemType e,aMaxSize;int i,j=1,k;doInitStack(st);gets(a);for(i=0;ai!=0;i+)if(ai=(|ai=|ai=) /左括号入栈Push(st,ai);if(ai=)if(StackEmpty(st) =1)/判断栈是否为空printf(多了“(”,不匹配n);break; else if(=st-data st-top )/匹配成功

7、出栈 Pop(st,&e); else printf(%c不匹配n,ai); break; if(ai=)if(StackEmpty(st) =1)/判断栈是否为空printf(多了“”,不匹配n); break; else if(=st-data st-top )/匹配成功出栈 Pop(st,&e); else printf(%c不匹配n,ai); break; if(ai=)if(StackEmpty(st) =1) /判断栈是否为空printf(多了“”,不匹配n);break; else if(=st-data st-top )/匹配成功出栈 Pop(st,&e); else prin

8、tf(%c不匹配n,ai); break;if(st-top =-1)printf(匹配成功n);elseprintf(匹配不成功,多了%c。n,st-data st-top );printf(是否继续匹配括号:(继续不要按“#”)n);scanf(%c,&e);k=getchar();/这是为了输入e时会敲回车键而加上去的while(e!=#);2.(1)#include /引入栈using namespace std;int main()int a,i;char b50;stacks;/声明了一个char型的栈,括号里面的可以改为任何基本类型gets(b);for(i=0;bi!=0;i+

9、)if(bi=(|bi=)s.push(bi); /如果为(或者是,就入栈if(bi=)if(s.empty()=1 )/s.empty是判断函数,若无栈顶元素就会返回1,表明栈为空,否则就会返回0printf(不匹配n);break;if(s.top()=()/判断是否符合出栈的条件s.pop() ;/匹配就会出栈elseprintf(不匹配n);break;if(bi=)if(s.empty() =1) /判断栈是否为空printf(不匹配n);break;if(s.top()=)s.pop() ;elseprintf(不匹配n);break;if(s.empty()=1&bi=0) /调

10、用函数,判断栈是否已经为空或者数组的右括号已经匹配完成printf(匹配成功n);if(s.empty()=0)/bi已经比较完了,但是若是栈里元素没有出栈,就不能说是匹配完全 printf(匹配不成功n);return 0;(2)#include iostream#include /引入栈using namespace std;int main()int a;stacks;/申请一个char型的栈printf(输入回车键结束入栈n);while(a=getchar()!=n)/一个一个的读入并匹配,若不匹配就跳出switch(a) /swith 是一种条件语句case:case(:s.push(a);continue;/或(就进栈case): case:if(s.empty()=0)s.pop();continue;elseprintf(右括号多出,配对失败。n);goto loop;if(s.empty()=0)printf(左括号多出,配对失败。n);else printf(配对成功!n); loop:return 0;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 单元课程

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com