1 / 13
文档名称:

【C语言《数据结构》实验报告】表达式的转换.doc

格式:doc   页数:13页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

【C语言《数据结构》实验报告】表达式的转换.doc

上传人:gyzhluyin 2015/12/17 文件大小:0 KB

下载得到文件列表

【C语言《数据结构》实验报告】表达式的转换.doc

相关文档

文档介绍

文档介绍:《数据结构》实验报告
◎实验题目: 使用键盘输入表达式,计算表达式的值并输出;将表达式转化成后缀表达式输出,利用后缀表达式求表达式的值并输出。
◎实验目的:使用栈的操作编写关于数据结构的程序。
◎实验内容:写出程序并上机调试、通过。
一、需求分析
1、演示程序以用户和计算机的对话方式执行,即在计算机终端上显示“请输入表达式”时输入中缀表达式。然后计算机终端输出转换后的后缀表达式及计算后的结果。
2、程序执行的命令包括:
(1)构造链栈;(2)输入数据;(3)判断输入的表达式是否为非法表达式;(4)将中缀表达式转换为后缀表达式;(5)计算表达式的值;(6)输出。(7)结束
4、本程序能将中缀表达式转换为后缀表达式,并且能计算表达式的值。
5、输入及输出示例:
例1:
请输入表达式
6+3*(6+5)
后缀表达式:6 3 6 5 + * +
计算结果为:39
Press any key to continue
例2:
请输入表达式
6-3*(7+1
ERROR:表达式错误
Press any key to continue
二概要设计

(1)、struct node
操作结果:创建结构体
(2)、int Searchexpression(char string1[])
初始条件:表达式string1已经存在。
操作结果:判断表达式是否非法
(3)、struct node *Initialization()
操作结果:创建栈链。
(4)、struct node *assort(struct node *s)
初始条件:string1、string2已存在。
操作结果:将中缀表达式转换为后缀表达式并存在string2中。
(5)、struct node *calcolate(struct node *s)
操作结果:求出表达式的值
2、模块调用图

主程序模块
创建结构体
判断表达式是否非法
将中缀表达式转换为后缀表达式
表达式求值
三详细设计
1、每个模块:
(1) 定义结构体
struct node
{
char data;
int num;
struct node *next;
};
(2) 判断表达式是否非法
int Searchexpression(char string1[])
{
int i1,b1,b2;
int m;
m=strlen(string1);
if(string1[0]<'0'||string1[0]>'9')
{
printf("ERROR:表达式缺操作数!\n");return(WRONG);
}
for(i1=0;i1<=m;i1++)
{
if(string1[i1]=='(')
b1++;
else
if(string1[i1]==')')
b2++;
}
if(b1!=b2)
{printf("ERROR:缺少括号\n");return(WRONG);}
for(i1=0;i1<m;i1++)
if('0'<=string1[i1]&&string1[i1]<='9'&&'0'<=string1[i1+1]&&string1[i1+1]<='9')
{ printf("ERROR:表达式缺操作符!\n");return(WRONG);}
for(i1=0;i1<=m;i1++)
if(string1[i1]=='+'&&(string1[i1+1]=='+'||string1[i1+1]=='-'||string1[i1+1]=='*'||string1[i1+1]=='/'))
{ printf("ERROR:表达式缺操作数!\n");return(WRONG);}
else
if(string1[i1]=='-'&&(string1[i1+1]=='+'||string1[i1+1]=='-'||string1[i1+1]=='*'||string1[i1+1]=='/'))
{ printf("ERROR:表达式缺操作数!\n");return(WRONG);}
else
if(string1[i1]=='*'&&(string1[i1+1]=='+'||string1[i1+1]=='-'||string1[i1+1]=='*'||string1[i1+1]=='/'))
{printf("ERROR:表达式缺操作数!\n");return(WRONG);}

else
if(string1[i1]=='/'&