小型桌面计算器源程序_第1页
小型桌面计算器源程序_第2页
小型桌面计算器源程序_第3页
小型桌面计算器源程序_第4页
小型桌面计算器源程序_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、小型桌面计算器源程序#include<iostream>#include<string>#include<map>#include<cctype>using namespace std;map<string,double>table;namespace Lexerenum Token_valueNAME,NUMBER,END,PLUS='+',MINUS='-',MUL='*',DIV='/',PRINT='',ASSIGN='=',LP=

2、'(',RP=')'Token_value curr_tok=PRINT;double number_value;string string_value;Token_value get_token();namespace Errorstruct Zero_divide;struct Syntax_errorconst char* p;Syntax_error(const char* q)p=q;namespace Parserdouble expr(bool get);double term(bool get);double prim(bool get);usi

3、ng namespace Lexer;using namespace Error;namespace Driverint no_of_errors;std:istream*input; void skip();Lexer:Token_value Lexer:get_token() char ch;cin>>ch;switch(ch)case'#':return curr_tok=END;case'':case'*':case'/':case'+':case'-':case'(&#

4、39;:case')':case'=':return curr_tok=Token_value(ch);case'0':case'1':case'2':case'3':case'4':case'5':case'6':case'7':case'8':case'9':case'.':cin.putback(ch);cin>>number_value;return curr_tok=

5、NUMBER;default:if(isalpha(ch)cin.putback(ch);cin>>string_value;return curr_tok=NAME;throw Error:Syntax_error("bad token");return curr_tok=PRINT;double Parser:expr(bool get) using namespace Lexer; double left=term(get); for(;) switch(curr_tok) case PLUS: left+=term(true); break; case

6、MINUS: left-=term(true); break; default: return left; double Parser:term(bool get)using namespace Lexer; double left=prim(get); for(;) switch(curr_tok) case MUL: left*=prim(true); break; case DIV: if(double d=prim(true) left/=d; break; throw Error:Zero_divide(); default: return left; double Parser:p

7、rim(bool get) using namespace Lexer;if(get)get_token();switch(curr_tok)case NUMBER:double v=number_value;get_token();return v;case NAME:double& v=tablestring_value;if(get_token()=ASSIGN)v=expr(true);return v;case MINUS:return-prim(true);case LP:double e=expr(true);if(curr_tok!=RP) throw Error:Sy

8、ntax_error(")expected");get_token();return e;case END:return 1;default:throw Error:Syntax_error("primary expected");void Driver:skip()no_of_errors+;while(*input) char ch;input->get(ch);switch(ch)case'n':case'':return ;int main(int argc,char*argv)cout<<&qu

9、ot;.欢迎使用桌面计算器."<<endl;cout<<"注意:1.如果输入了一个以字母开头的标识符"cout<<"请在标识符的后面加上一个空格,否则程序将会出错"<<endl;cout<<"2.若输入了一个表达式,切记在后面加上;号"<<endl;cout<<"3.若想退出程序,请输出#"<<endl;Driver:input=&cin; table"pi"=3.141592653

10、5897932385; table"e"=2.7182818284590452354; while(*Driver:input) try Lexer:get_token(); if(Lexer:curr_tok=Lexer:END)break; if(Lexer:curr_tok=Lexer:PRINT) continue; cout<<Parser:expr(false)<<endl; catch(Error:Zero_divide) cerr<<"attempt to divide by zero"<<endl; if(Lexer:curr_tok!=Lexer:PRINT) Driver:skip(); catch(Error:Syntax_error e) cerr<<"syntax error:"<<e.p<<endl; if(Lex

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论