下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年互联网医疗解决方案技术合作协议
- 2025年双方协商劳务派遣协议
- 2025年PPP项目合作财务管理协议
- 主材供应及合作框架合同 2024年版一
- 2025版区块链技术应用合伙人合作协议3篇
- 2025年度智能建筑安装工程承包技师合同4篇
- 二零二五年度酒吧食品安全管理与承包合同
- 2025年度城市公交车定点维修与应急保障合同
- 二零二五年度汽车维修免责声明适用于车主自带配件
- 2025年度地铁隧道钢筋工劳务施工安全质量保障合同
- 建筑结构课程设计成果
- 班级建设方案中等职业学校班主任能力大赛
- 纤维增强复合材料 单向增强材料Ⅰ型-Ⅱ 型混合层间断裂韧性的测定 编制说明
- 习近平法治思想概论教学课件绪论
- 宠物会展策划设计方案
- 孤残儿童护理员(四级)试题
- 梁湘润《子平基础概要》简体版
- 医院急诊医学小讲课课件:急诊呼吸衰竭的处理
- 肠梗阻导管在临床中的使用及护理课件
- 小学英语单词汇总大全打印
- 卫生健康系统安全生产隐患全面排查
评论
0/150
提交评论