- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c语言版计算器实验报告
计算器实验报告
班级: 07计本(1)班
姓名: 王林
学号: 20706031047
指导老师: 韩静
需求分析
制作一个计算器界面工程,有数字运算符等键,输入表达式后,按等号键输入结束,并显示出正确的结果。
程序能根据运算符的高低进行运算
可以输入括号
设计思路
用工程建立一个字符串的类结构,并用编辑框输入相应的数字和字符,并且输入的字符用字符串逐个接受,当输入为’=’的时候,用‘#‘做最后一个输入。
开始对所输入的字符串进行运算和操作,显示在工程中的编辑框内。
如果结束则关闭,如果再次进行运算则进行清零。
主程序段
char Precede(char a,char b) //判断优先级的函数
{
switch(a)
{
case+:{if(b==*||b==/||b==() return();
else return();
}
case-:{if(b==*||b==/||b==() return();
else return();
}
case*:{if(b==() return();
else return();
}
case/:{if(b==() return();
else return();
}
case(:{if(b==)) return(=);
else if(b==#) return(0);
else return();
}
case):{if(b==() return(0);
else return();
}
case#:{if(b==)) return(0);
else if(b==#) return(=);
else return();
}
}
}
float Operate(float a,char theta,float b) //计算两个数的结果的函数
{
float z;
switch(theta){
case +:z=a+b;break;
case -:z=a-b;break;
case *:z=a*b;break;
case /:z=a/b;break;
}
return(z);
}
float Shuhe(SqStack1 OP,int k,int j) //输入的字符转化为数字的函数
{
int i,e,n=k;
float sum=0,fe;
while(j!=0)
{
Pop1(OP,e);
fe=float(e);
for(i=1;i=j;i++)
fe=fe/10;
sum=sum+fe;
j--;
}
while(k!=0)
{
Pop1(OP,e);
for(i=0;in-k;i++)
e=e*10;
sum=sum+e;
k--;
}
return(sum);
}
void CMyDlg::OnButton12()
{
UpdateData(TRUE);
m_ss=m_ss+#;
SqStack OPTR; //字符型栈的定义
SqStack1 OP; //整型型栈的定义
SqStack2 OPND; //浮点型栈的定义
int i=0,flag=0,k=0,tag=0,j=0;
float sum,a,b;
char c,x,theta;
InitStack(OPTR); Push(OPTR,#);
InitStack2(OPND);InitStack1(OP);
c=m_ss[i++];
while(c!=#||GetTop(OPTR)!=#)
{
if(c==.)
{
tag=1;c=m_ss[i++];
}
else if(c=0c=9)
{
Push1(OP,int(c)-48);
c=m_ss[i++];
if(tag==0) k++;
else j++;
flag=1;
}
else
{
if(flag
文档评论(0)