大数据结构算术表达式求值实验报告材料文档格式.docx
- 文档编号:15961248
- 上传时间:2022-11-17
- 格式:DOCX
- 页数:18
- 大小:61.19KB
大数据结构算术表达式求值实验报告材料文档格式.docx
《大数据结构算术表达式求值实验报告材料文档格式.docx》由会员分享,可在线阅读,更多相关《大数据结构算术表达式求值实验报告材料文档格式.docx(18页珍藏版)》请在冰豆网上搜索。
在计算机中,算术表达式由常量、变量、运算符和括号组成。
由于不同的运算符具有不同的优先级,又要考虑括号,因此,算术表达式的求值不可能严格地从左到右进行。
因而在程序设计时,借助栈实现。
算法输入:
一个算术表达式,由常量、变量、运算符和括号组成(以字符串形式输入)。
为简化,规定操作数只能为正整数,操作符为+、-*、/、=,用#表示结束。
算法输出:
表达式运算结果。
算法要点:
设置运算符栈和运算数栈辅助分析算符优先关系。
在读入表达式的字符序列的同时,完成运算符和运算数的识别处理,以及相应运算。
2.概要设计
2.1数据结构设计
任何一个表达式都是由操作符,运算符和界限符组成的。
我们分别用顺序栈来寄存表达式的操作数和运算符。
栈是限定于紧仅在表尾进行插入或删除操作的线性表。
顺序栈的存储结构是利用一组连续的存储单元依次存放自栈底到栈顶的数据元素,同时附设指针top指示栈顶元素在顺序栈中的位置,base为栈底指针,在顺序栈中,它始终指向栈底,即top=base可作为栈空的标记,每当插入新的栈顶元素时,指针top增1,删除栈顶元素时,指针top减1。
2.2算法设计
为了实现算符优先算法。
可以使用两个工作栈。
一个称为OPTR,用以寄存运算符,另一个称做OPND,用以寄存操作数或运算结果。
1.首先置操作数栈为空栈,表达式起始符”#”为运算符栈的栈底元素;
2.依次读入表达式,若是操作符即进OPND栈,若是运算符则和OPTR栈的栈顶运算符比较优先权后作相应的操作,直至整个表达式求值完毕(即OPTR栈的栈顶元素和当前读入的字符均为”#”)。
2.3ADT描述
ADTStack{
数据对象:
D={
|
∈ElemSet,i=1,2,…,n,n≧0}
R1={<
>
|
i=2,…,n}
约定
端为栈顶,
端为栈底。
InitStack(&
S)
操作结果:
构造一个空栈S。
GetTop(S)
初始条件:
栈S已存在。
用P返回S的栈顶元素。
Push(&
S,ch)
插入元素ch为新的栈顶元素。
Pop(&
删除S的栈顶元素。
In(ch)
操作结果:
判断字符是否是运算符,运算符即返回1。
Precede(c1,c2)
初始条件:
c1,c2为运算符。
判断运算符优先权,返回优先权高的。
Operate(a,op,b)
a,b为整数,op为运算符。
a与b进行运算,op为运算符,返回其值。
num(n)
返回操作数的长度。
EvalExpr()
输入表达式合法。
返回表达式的最终结果。
}ADTStack
2.4功能模块分析
1.栈的基本功能。
InitStack(Stack*s)和InitStack2(Stack2*s)分别构造运算符栈与构造操作数栈,
Push(Stack*s,charch)运算符栈插入ch为新的栈顶元素,
Push2(Stack2*s,intch)操作数栈插入ch为新的栈顶元素,
Pop(Stack*s)删除运算符栈s的栈顶元素,用p返回其值,
Pop2(Stack2*s)删除操作数栈s的栈顶元素,用p返回其值,
GetTop(Stacks)用p返回运算符栈s的栈顶元素,
GetTop2(Stack2s)用p返回操作数栈s的栈顶元素。
2.其它功能分析。
(1)In(charch)判断字符是否是运算符功能,运算符即返回1,该功能只需简单的一条语句即可实现,return(ch=='
+'
||ch=='
-'
*'
/'
('
)'
#'
)。
(2)Precede(charc1,charc2)判断运算符优先权功能,该函数判断运算符c1,c2的优先权,具体优先关系参照表1。
(3)Operate(inta,charop,intb)操作数用对应的运算符进行运算功能。
运算结果直接返回。
(4)num(intn)求操作数的长度功能,需要用itoa函数把int型转换成字符串型,strlen函数可求字符长度。
(5)EvalExpr()主要操作函数运算功能。
分析详细见“3.详细设计…3.2”。
3.详细设计
3.1数据存储结构设计
因为表达式是由操作符,运算符和界限符组成的。
如果只用一个char类型栈,不能满足2位以上的整数,所以还需要定义一个int类型的栈用来寄存操作数。
/*定义字符类型栈*/
structstacklifei1//数字栈的定义
{
double*base;
double*top;
}s1;
/
structstacklifei2//运算符栈的定义
char*base;
char*top;
}s2;
3.2计算功能的实现
voidjisuan()//该函数对数字栈的前两个栈顶
//元素与符号栈的栈顶元素完成一次运算操作
doublea,b;
b=*(s1.top-1);
s1.top--;
if(s1.top==s1.base)
{
error=1;
return;
}
a=*(s1.top-1);
switch(*(s2.top-1))
case'
:
a=a+b;
break;
a=a-b;
a=a*b;
if(b==0){error=2;
s2.top=s2.base;
return;
}//除数不为0
elsea=a/b;
default:
error=1;
}
fprintf(file,"
%lf%c%lf=%lf\n"
*(s1.top-1),*(s2.top-1),b,a);
*(s1.top-1)=a;
//将运算结果入栈
s2.top--;
return;
}
3.3函数表达式求值功能的实现
voidqiuzhi(char*cr)
该函数完成对表达式的处理
inti=0,k,h,flag,fuhao=0;
doublesum,j;
s1.base=s1.top=shuzhi;
s2.base=s2.top=fuha;
*(s2.top)='
;
s2.top++;
while(s2.top!
=s2.base)
sum=0;
flag=0;
k=10;
j=1;
h=1;
while(cr[i]>
='
0'
&
cr[i]<
9'
||cr[i]=='
.'
)
//若当前的字符是数字,就将char型的数据转换为double型
{
if(cr[i]=='
{
if(cr[i-1]<
'
||cr[i-1]>
||i==0||cr[i+1]<
||cr[i+1]>
{error=1;
else
{k=1;
h=10;
}
else
flag=1;
j=j*h;
sum=sum*k+(cr[i]-48)/j;
i++;
}
3.4对函数表达式每个字符的操作
switch(cr[i])
case'
if(cr[i-1]=='
||i==0){fuhao=1;
i++;
//判断是不是负号,若不是则进行与加号相同的操作
//当'
出现在表达式第一位或是'
后第一位,则应将其判为负号
//加、减号的优先级只比'
和'
高,若栈顶元素为这两者之一
//就将其入栈,否则执行运算操作
if(*(s2.top-1)=='
||*(s2.top-1)=='
{
*(s2.top)=cr[i];
s2.top++;
i++;
}
elsejisuan();
//乘、除号的优先级只比'
、'
^'
低,若栈顶元素为这三者之一
//就执行运算操作,否则将其入栈
)jisuan();
else
}break;
*(s2.top)=cr[i];
//未入栈时'
的优先级最高,所以它一定要入栈
//但一入栈其优先级就应降为最低
//注意:
由于'
()'
运算优先级最高故我直接进行运算,
//直到栈顶元素为'
后将'
出栈,故符号栈中一定没有'
,
//这也是我进行以上优先级判断的前提
s2.top--;
//表达式结束,若符号栈栈顶元素不为'
,进行运算
//否则退栈,结束
default:
//清除空格及未定义符号
3.5主菜单页面的实现
voidmain()
charcr[60];
charc='
a'
file=fopen(outfile,"
w+"
);
//使用提示
printf("
*******************************************************************************\n"
*********************************斐计算器************************************\n"
四则简易计算器\n\n"
输入表达式例如2+4=\n\n"
最后按#键则会退出保存\n\n"
谢谢使用\n
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 算术 表达式 求值 实验 报告 材料