下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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; while(*Driver:input) try Lexer:
10、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(Lexer:c
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 产品经理考试备考手册含答案
- 财务分析师面试专业问题与答案解析
- 2026年计算机知识题库500道含完整答案【历年真题】
- 2026年县乡教师选调进城考试《教育学》题库300道含答案【基础题】
- 2026年安全员考试题库300道及答案(历年真题)
- 2026年基金从业资格证考试题库500道含答案ab卷
- 生产运营经理面试题及答案
- 2026年试验检测师之交通工程考试题库300道及参考答案(典型题)
- 2026年交管12123学法减分复习考试题库(历年真题)
- 作业没写检讨书15篇
- 2025年看守所民警述职报告
- 景区接待员工培训课件
- 客源国概况日本
- 学位授予点评估汇报
- 《Stata数据统计分析教程》
- 2024-2025学年广州市越秀区八年级上学期期末语文试卷(含答案)
- 2025年学法普法考试答案(全套)
- 《三只小猪盖房子》拼音版故事
- GB 7101-2022食品安全国家标准饮料
- YS/T 921-2013冰铜
- GB/T 6072.1-2008往复式内燃机性能第1部分:功率、燃料消耗和机油消耗的标定及试验方法通用发动机的附加要求
评论
0/150
提交评论