资源描述:
《1305120411_何彬_实验报告03》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、计算机科学与工程学院计算机科学与工程学院《算法与数据结构》实验报告(三)专业班级2013网络工程01实验地点423机房学生学号1305120411指导教师赵卿松学生姓名何彬实验时间2015-4-24实验项目栈的应用实验类别基础性(√)设计性()综合性()其它()实验目的及要求(1)掌握栈的特点及其存储方法;(2)掌握栈的常见算法以及程序实现;(3)了解递归的工作过程。成绩评定表类别评分标准分值得分合计上机表现积极出勤、遵守纪律按要求完成设计任务30分程序与报告程序代码规范、功能正确报告详实完整、体
2、现收获70分说明:评阅教师:赵卿松日期:2015年4月25日7《算法与数据结构》实验报告计算机科学与工程学院实验内容实验内容:表达式求值问题。这里限定的表达式求值问题是:用户输入一个包含“+”、“-”、“*”、“/”、正整数和圆括号的合法数学表达式,计算该表达式的运算结果。算术表达式求值过程是:STEP1:先将算术表达式转换成后缀表达式。STEP2:然后对该后缀表达式求值。实验说明:在设计相关算法中用到栈,这里采用顺序栈存储结构。初始化运算符栈op;将'='进栈;从exp读取字符ch;while(
3、ch!=' '){if(ch不为运算符) 将后续的所有数字均依次存放到postexp中,并以字符'#'标志数值串结束;elseswitch(Precede(op栈顶运算符,ch)){case'<'://栈顶运算符优先级低将ch进栈;从exp读取下字符ch;break;case'='://只有栈顶运算符为'(',ch为')'的情况退栈;从exp读取下字符ch;break;case'>'://栈顶运算符应先执行,所以出栈并存放到postexp中退栈运算符并将其存放到postexp中;break;
4、}}若字符串exp扫描完毕,则将运算符栈op中'='之前的所有运算符依次出栈并存放到postexp中。最后得到后缀表达式postexp;中缀表达式exp==》后缀表达式postexp伪代码如下:对后缀表达式postexp求值伪代码如下:while(从postexp读取字符ch,ch!=' '){若ch为数字,将后续的所有数字构成一个整数存放到数值栈st中。若ch为“+”,则从数值栈st中退栈两个运算数,相加后进栈st中。若ch为“-”,则从数值栈st中退栈两个运算数,相减后进栈st中。若ch为“
5、*”,则从数值栈st中退栈两个运算数,相乘后进栈st中。若ch为“/”,则从数值栈st中退栈两个运算数,相除后进栈st中(若除数为零,则提示相应的错误信息)。}若字符串postexp扫描完毕,则数值栈op中的栈顶元素就是表达式的值。7《算法与数据结构》实验报告计算机科学与工程学院实验内容#include#include#definemaxsize100//中缀表达式str转换为后缀表达式expvoidtrans(charstr[],charexp[]){str
6、uct{chardata[maxsize];inttop;}op;charch;inti=0,t=0;op.top=-1;ch=str[i];i++;while(ch!=' '){switch(ch){case'(':op.top++;op.data[op.top]=ch;break;case')':while(op.data[op.top]!='('){exp[t]=op.data[op.top];op.top--;t++;}op.top--;break;case'+':case'-':whi
7、le(op.top!=-1&&op.data[op.top]!='('){exp[t]=op.data[op.top];op.top--;t++;}op.top++;op.data[op.top]=ch;break;7《算法与数据结构》实验报告计算机科学与工程学院case'*':case'/':while(op.data[op.top]=='*'
8、
9、op.data[op.top]=='/'){exp[t]=op.data[op.top];op.top--;t++;}op.top++;op.data
10、[op.top]=ch;break;case'':break;default:while(ch>='0'&&ch<='9'){exp[t]=ch;t++;ch=str[i];i++;}i--;exp[t]='#';t++;}ch=str[i];i++;}while(op.top!=-1){exp[t]=op.data[op.top];t++;op.top--;}exp[t]=' ';}//后缀表达式的求值floatcompvalue(charexp[]){struct{float