亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

小型計算器A small software project

2019-11-11 07:46:40
字體:
來源:轉載
供稿:網友

小型計算器

一個小型的軟件項目,代碼大概1000行左右,包括了很多知識(繼承、多態、前向聲明、虛函數、動態內存、引用、指針等等),從頭到尾寫完花了些時間,但覺得很受用。 (1)計算器程序的目的是接受用戶提供的算術表達式(例:1+2*3),求其值顯示結果。 (2)每個算術表達式由解析器分析,將輸入的算法表達式(一串字符)轉換成一個算術樹。 (3)算術樹(一種數據結構):算術表達式可以轉換為一個二叉樹結構。 如:(a+b×(c-d))-e/f 二叉樹結構為: 這里寫圖片描述

解析器語法

解析式尋找一個表達式,語法定義如下: 1. An exPRession is(一個表達式是) a. 一個后面有加號或減號的項,加號或減號后面是另一個表達式。例:表達式2-3,2是一個項(后面是減號),3是一個表達式。 b. 如果表達式不含有加號、減號,它等于項。 (例:上例中的3是一個表達式,它也是一個項)

2. A term is(一個項是) a. 被另一個項乘除的因子。 (例:表達式1+2*3,2*3是一個表達式,滿足1b條件,2*3是一個項,滿足2a條件,2是一個因子) b.項如果不包含乘除,它等于此因子。

3. A factor can be(一個因子是) a. 數字 b. 對應某變量的標識符 c. 后面帶有一個因子的減號 d. 小括號中的整個表達式

配合實例理解解析器的語法定義: 1+x*(2-y) 這里寫圖片描述

具體實現

計算器由以下幾個對象組成: (1)掃描器,掃描用戶輸入的字符串。 (2)符號表,使計算器可以處理符號變量,如(x=1,變量x代表1) (3)存儲器,讓計算器具有記憶能力,可以保存用戶自定義變量的值。 (4)函數表,讓計算器事先具有一些函數(如sin、cos、log、exp) (5)結點,對應算術樹的每個結點(使用繼承實現)。關于結點的簡化版本參看C++多態 (6)解析器,實現算數表達式的解析。

代碼:只給出主函數、解析器代碼,剩下的代碼可以從github下載。 計算器Github 主函數 calculator.cpp

#include"SymbolTable.h"#include"FunctionTable.h"#include"Store.h"#include"Scanner.h"#include"Parser.h"const int maxBuf = 100;const int maxSymbols = 40;int main(){ char buf[maxBuf]; //狀態位 Status status; //符號表 SymbolTable symTab(maxSymbols); //函數表 FunctionTable funTab(symTab, funArr); //存儲器 Store store(maxSymbols, symTab); do { std::cout << "> "; std::cin.getline(buf, maxBuf); //掃描器 Scanner scanner(buf); //解析器 Parser parser(scanner, store, funTab, symTab); status = parser.Eval(); } while (status != stQuit); return 0;}

解析器 Parser.h

#ifndef PARSER_H#define PARSER_Hclass Node;class Scanner;class SymbolTable;class Store;class FunctionTable;//枚舉:狀態enum Status{ stOK, stQuit, stError};//解析器類class Parser{public: Parser(Scanner & scanner, Store& store, FunctionTable& funTab, SymbolTable & symTab); ~Parser(); Status Eval();private: void Parse(); Node* Expr(); Node* Term(); Node* Factor(); void Execute(); Scanner & _scanner;//掃描器 SymbolTable & _symTab;//符號表 Node* _pTree;//算術樹 Status _status;//狀態位 Store& _store;//存儲器 FunctionTable& _funTab;//函數表};#endif

Parser.cpp

#include "Parser.h"#include<iostream>#include"Store.h"#include"Node.h"#include"FunctionTable.h"#include"SymbolTable.h" #include"Scanner.h"#include"AddNode.h"#include "AssignNode.h"#include"SubNode.h"#include"MultNode.h"#include"DivideNode.h"#include"NumNode.h"#include"FunNode.h"#include"VarNode.h"#include"UMinusNode.h"Parser::~Parser(){ delete _pTree;} Parser::Parser(Scanner & scanner, Store& store, FunctionTable& funTab, SymbolTable & symTab) :_scanner(scanner), _pTree(0), _status(stOK), _funTab(funTab), _store(store), _symTab(symTab){ std::cout << "Parser Created" << std::endl;}//解析記號Status Parser::Eval(){ Parse(); if (_status == stOK) Execute(); else _status == stQuit; return _status; //for (EToken token = _scanner.Token(); // token != tEnd; // _scanner.Accept()) //{ // token = _scanner.Token(); // switch (token) // { // case tMult: // std::cout << "Times" << std::endl; // break; // case tPlus: // std::cout << "Plus" << std::endl; // break; // case tNumber: // std::cout << "Number: " << _scanner.Number() << std::endl; // break; // case tEnd: // std::cout << "End" << std::endl; // return stQuit; // case tError: // std::cout << "Error" << std::endl; // return stQuit; // default: // std::cout << "Error: bad token" << std::endl; // return stQuit; // } //} //return stOK;}void Parser::Execute(){ if (_pTree) { double result = _pTree->Calc(); std::cout << " " << result << std::endl; }}void Parser::Parse(){ _pTree = Expr();}//表達式Node* Parser::Expr(){ Node* pNode = Term(); EToken token = _scanner.Token(); //加 if (token == tPlus) { //識別下一個記號 _scanner.Accept(); Node* pRight = Expr(); pNode = new AddNode(pNode, pRight); } //減 else if (token==tMinus) { _scanner.Accept(); Node* pRight = Expr(); pNode = new SubNode(pNode, pRight); } //賦值 else if (token == tAssign) { _scanner.Accept(); Node* pRight = Expr(); //左值 if (pNode->IsLvalue()) { pNode = new AssignNode(pNode, pRight); } else { _status = stError; delete pNode; pNode = Expr(); } } return pNode;}//項Node* Parser::Term(){ Node* pNode = Factor(); //Term is Factor * Term if (_scanner.Token() == tMult) { _scanner.Accept(); Node* pRight = Term(); pNode = new MultNode(pNode, pRight); } //Term is Factor/Term else if (_scanner.Token()==tDivide) { _scanner.Accept(); Node* pRight = Term(); pNode = new DivideNode(pNode, pRight); } //Term is Factor return pNode;}//因子Node* Parser::Factor(){ Node* pNode; EToken token = _scanner.Token(); //左括號 if (token == tLParen) { _scanner.Accept();//accept '(' pNode = Expr(); if (_scanner.Token() != tRParen) _status = stError; _scanner.Accept();//accept ')' } //數字 else if (token == tNumber) { pNode = new NumNode(_scanner.Number()); _scanner.Accept(); } //符號變量 else if (token == tIdent) { char strSymbol[maxSymLen + 1]; int lenSym = maxSymLen; //復制symbol到strSymbol _scanner.GetSymbolName(strSymbol, lenSym); int id = _symTab.Find(strSymbol); _scanner.Accept(); //函數調用 如sin(x) if (_scanner.Token() == tLParen) { _scanner.Accept(); pNode = Expr(); if (_scanner.Token() == tRParen) _scanner.Accept(); else _status = stError; if (id != idNotFound && id < _funTab.Size()) { //函數結點 pNode = new FunNode(_funTab.GetFun(id), pNode); } else { std::cout << "Unknow function/""; std::cout << strSymbol << "/"/n"; } } else { if (id == idNotFound) id = _symTab.ForcAdd(strSymbol, lenSym); pNode = new VarNode(id, _store); } } //一元減 else if (token == tMinus) { _scanner.Accept(); pNode = new UMinusNode(Factor()); } else { _scanner.Accept(); _status = stError; pNode = 0; } return pNode;}

這里寫圖片描述 這里寫圖片描述 這里寫圖片描述


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品国产免费| 欧美性极品xxxx娇小| 亚洲开心激情网| 国产91色在线|| 91免费在线视频网站| 66m—66摸成人免费视频| 亚洲免费电影在线观看| 久久精品视频99| 亚洲福利影片在线| 国产精品欧美日韩一区二区| 日韩美女中文字幕| 91经典在线视频| 亚洲一区二区中文| 国产亚洲欧美视频| 久久精品影视伊人网| 日韩欧美国产成人| 在线国产精品视频| 一本色道久久88精品综合| 日韩欧美aⅴ综合网站发布| 欧美俄罗斯乱妇| 日韩理论片久久| 久久久久久成人精品| 国产日韩在线精品av| 中文字幕亚洲情99在线| 国产精品久久久久久久久久久不卡| 日韩视频一区在线| 米奇精品一区二区三区在线观看| 色综合久久中文字幕综合网小说| 亚洲电影免费在线观看| 亚洲精品白浆高清久久久久久| 久久久人成影片一区二区三区| 国产精品免费观看在线| 色综合老司机第九色激情| 精品国内产的精品视频在线观看| 欧美激情一级欧美精品| 亚洲综合第一页| 亚洲欧美日韩精品久久奇米色影视| 国产成人精品视频在线观看| 91精品啪aⅴ在线观看国产| 国产精品久久久久久久午夜| 亚洲国产日韩欧美在线图片| 国产91成人video| 日本欧美国产在线| 国产精品久久久久久久久久久不卡| 国产精品九九久久久久久久| 欧美性猛交xxxx免费看| …久久精品99久久香蕉国产| 亚洲欧美一区二区精品久久久| 国产一区二区三区精品久久久| 成人国产精品久久久久久亚洲| 91精品国产色综合久久不卡98| 国产性猛交xxxx免费看久久| 日韩av网站在线| 国产福利精品视频| 久久综合五月天| 亚洲天堂男人的天堂| 91精品久久久久久久久久| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品女人久久久久久| 国产欧美日韩精品丝袜高跟鞋| 日韩精品免费在线观看| 久久久91精品国产| 久久久久久网站| 在线观看91久久久久久| 欧美成人黄色小视频| 欧美人交a欧美精品| 国产色婷婷国产综合在线理论片a| 在线观看国产欧美| 亚洲高清久久网| 国产精品一区久久| 久久国产精品免费视频| 欧美成人一区二区三区电影| 国产亚洲日本欧美韩国| 亚洲欧美激情在线视频| 97国产成人精品视频| 亚洲白虎美女被爆操| 日本一区二区在线播放| 在线观看亚洲视频| 亚洲精品美女在线观看播放| 亚洲国产91色在线| 久久久久久免费精品| 欧美乱大交做爰xxxⅹ性3| 欧美激情a∨在线视频播放| 日韩av在线免费观看一区| 久久99国产精品久久久久久久久| 欧美一区二区视频97| 国产精品久久激情| 国产在线视频不卡| 中文字幕日韩电影| 久久99久久99精品免观看粉嫩| 97免费中文视频在线观看| 日韩在线免费视频观看| 久久激情视频久久| 在线视频欧美日韩精品| 韩剧1988在线观看免费完整版| 欧美国产在线电影| 日韩视频免费中文字幕| 97国产在线视频| 国产欧美欧洲在线观看| 日韩美女视频在线观看| 一区二区三区日韩在线| 久久久999精品视频| 亚洲性日韩精品一区二区| 97碰碰碰免费色视频| 中文字幕免费精品一区高清| 色综合老司机第九色激情| 国产欧美日韩精品在线观看| 中文字幕视频在线免费欧美日韩综合在线看| 成人免费福利在线| 第一福利永久视频精品| 97精品国产91久久久久久| 亚洲久久久久久久久久| 91久久嫩草影院一区二区| 亚洲一级黄色av| 亚洲精品自在久久| 欧美专区福利在线| 美乳少妇欧美精品| 亚洲最大福利视频网站| 一区二区三区动漫| 91精品国产自产在线观看永久| 欧美精品激情视频| 26uuu亚洲伊人春色| 亚洲欧美中文日韩在线| 日韩高清电影好看的电视剧电影| 国产在线视频欧美| 国色天香2019中文字幕在线观看| 久久久久久久久久亚洲| 欧美性猛交xxx| 欧美黄色免费网站| 黄色成人av网| 国产精品久久久久久一区二区| 久久亚洲欧美日韩精品专区| 国产精品午夜一区二区欲梦| 久久久久国产一区二区三区| 亚洲欧美制服丝袜| 久久国产精品久久久久| 成人午夜在线观看| 国产91色在线播放| 最近2019年好看中文字幕视频| 8090成年在线看片午夜| 亚洲电影天堂av| 欧洲美女免费图片一区| 日韩av一区在线观看| 中文字幕在线看视频国产欧美在线看完整| 成人免费高清完整版在线观看| 欧美日韩中文字幕在线| 欧美激情视频网| 亚洲一区999| 亚洲精品视频播放| 精品国产区一区二区三区在线观看| 一个人看的www欧美| 欧美另类极品videosbest最新版本| 5566成人精品视频免费| 国产精品www色诱视频| 在线日韩精品视频| 亚洲人成毛片在线播放| 尤物yw午夜国产精品视频| 黄色91在线观看| 中文欧美在线视频| 成人黄色大片在线免费观看| 亚洲一区二区三区久久| 精品久久久久久久久久久久久| 久久精品99无色码中文字幕| 国产成人涩涩涩视频在线观看|