- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验二 栈的应用---算术表达式的计算
浙江大学城市学院实验报告
课程名称 数据结构与算法
实验项目名称 实验二 栈的应用---算术表达式的计算
实验成绩 指导老师(签名 ) 日期
实验目的和要求
1.进一步掌握栈的基本操作的实现。
2.掌握栈在算术表达式的计算方面的应用。
二. 实验内容
1. 编写程序利用栈将中缀表达式转换成后缀表达式,即从键盘输入任一个中缀表达式(字符串形式),转换成后缀表达式后,将后缀表达式输出。假设:中缀表达式包含圆括号 ( ) 及双目运算符 +、-、*、/、^(乘方)。要求:把栈的基本操作的实现函数存放在头文件stack1.h中(栈元素的类型为char),在主文件test6_2.cpp中包含将中缀表达式S1转换成后缀表达式S2的转换函数void Change( char *S1, char *S2 ) 及主函数,在主函数中进行输入输出及转换函数的调用。
2. 选做:编写利用栈对后缀表达式进行求值的函数double Compute(char *str),以计算从前述程序得到的后缀表达式的值。要求:把栈的基本操作的实现函数存放在头文件stack2.h中(栈元素的类型为double),在主文件test6_2.cpp中添加后缀表达式求值函数,并在主函数中增加调用求值函数及输出结果值的语句。
3. 填写实验报告,实验报告文件取名为report2.doc。
4. 上传实验报告文件report2.doc与源程序文件stack1.h、stack2.h(若有)及test6_2.cpp到Ftp服务器上你自己的文件夹下。
函数的功能说明及算法思路(算法思路见源程序的注释部分)
//栈的顺序存储结构定义
struct Stack{
ElemType *stack;
int top;
int MaxSize;
};
//初始化栈S为空
void InitStack(Stack S)
//元素item进栈,即插入到栈顶
void Push(Stack S,ElemType item)
//删除栈顶元素并返回
ElemType Pop(Stack S)
//读取栈顶元素的值
ElemType Peek(Stack S)
//判断S是否为空,若是则返回true,否则返回false
bool EmptyStack(Stack S)
//清除栈S中的所有元素,释放动态存储空间
void ClearStack(Stack S)
//将中缀算术表达式转换为后缀算术表达式
void Change(char *S1,char *S2)
//返回运算符op所对应的优先级数值
int Precedence(char op)
//计算由str所指字符串的后缀表达式的值
double Compute(char *str)
四. 实验结果与分析
五. 心得体会
【附录----源程序】
test6_2.cpp
#includeiostream.h
#includestdlib.h
#includemath.h
#includestack1.h
#includestack2.h
void main()
{
char x[30],y[30];
double r;
while(1){
cout请输入一个中缀算术表达式:;
cin.getline(x,sizeof(x));
Change(x,y);
cout对应的后缀算术表达式为:;
coutyendl;
r=Compute(y);
cout后缀算术表达式值为:rendlendl;
}
}
stack1.h
typedef char ElemType1;
struct Stack1{
ElemType1 *stack;
int top;
int MaxSize;
};
void InitStack(Stack1 S)
{
S.MaxSize=10;
S.stack=new ElemType1[S.MaxSize];
if(!S.stack){
cerr动态储存分配失败endl;
exit(1);
}
S.top=-1;
}
void Push(Stack1 S,ElemType1 item)
{
if(S.top==S.MaxSize-1){
int k=sizeof(ElemType1);
S.stack=(ElemType1*)realloc(S.stack,2*S.MaxSize*k);
S.MaxSize=2*S.MaxSize;
}
S.top++
您可能关注的文档
- 大学本科vfp,ppt课件6.ppt
- 第9课 修改零件模型.ppt
- 高中英语:Unit 10《Money》测试(北师大版必修4).doc
- 第二章:Silverlight编程模型.ppt
- 汉洛塔的实现-数据结构.doc
- iTELLIN巡检报告模板.doc
- 初二下期末三大版本Top 10考点---秦秀玲.doc
- TOP TEN讲解.ppt
- 中国大陆美国留学最强中学TOP50榜-2015.docx
- 栈的基本结构和操作(C语言实现).doc
- 湖南省娄底市2024–2025学年高一物理上学期期末统考试卷【含答案】.pdf
- 2025年跨境文具礼品电商供应链整合与产业链垂直整合.docx
- 元宇宙社交平台虚拟现实社交平台用户增长策略与发展瓶颈.docx
- 2025年跨境文具礼品电商供应链优化策略研究报告.docx
- 2025年数据中心运营风险评估与绿色节能策略报告.docx
- 医院周年庆活动方案.docx
- 新能源汽车在城市公共交通电动化进程中的充电设施建设与运营管理优化报告.docx
- 2025年跨境数码电商领域维修技术合作前景评估报告.docx
- 工业机器人在2025柔性制造系统中智能调度与路径规划技术分析报告.docx
- 制造业:2025年制造业智能化设备研发与创新趋势.docx
最近下载
- 最地震演练脚本.docx VIP
- 《国有企业管理人员处分条例》解读.docx VIP
- 《无机及分析化学》课件 第7章 物质结构基础.ppt VIP
- Kyocera京瓷ECOSYS M4125idn_M4132idn操作手册.pdf
- 含糖透析液对血透病人的影响.doc VIP
- RADWIN5000安装调试指南.doc VIP
- 无机及分析化学:第四章 物质结构简介.ppt VIP
- 体育康养与自然疗法的结合研究论文.docx VIP
- 2025年广东省基层住院医师线上岗位培训《医学人文及医患沟通》-中医学专业培训课程公共课答案.docx VIP
- 含糖透析液对糖尿病肾病血液透析患者血压和心率变异性影响.doc VIP
文档评论(0)