小型桌面計(jì)算器源程序_第1頁
小型桌面計(jì)算器源程序_第2頁
小型桌面計(jì)算器源程序_第3頁
小型桌面計(jì)算器源程序_第4頁
小型桌面計(jì)算器源程序_第5頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、小型桌面計(jì)算器源程序#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;.歡迎使用桌面計(jì)算器."<<endl;cout<<"注意:1.如果輸入了一個(gè)以字母開頭的標(biāo)識(shí)符"cout<<"請(qǐng)?jiān)跇?biāo)識(shí)符的后面加上一個(gè)空格,否則程序?qū)?huì)出錯(cuò)"<<endl;cout<<"2.若輸入了一個(gè)表達(dá)式,切記在后面加上;號(hào)"<<endl;cout<<"3.若想退出程序,請(qǐng)輸出#"<<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等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論