µ±Ç°Î»ÖãºÊ×Ò³ > Ìì½òÀí¹¤´óѧ±àÒëÔÀíʵÑé3£ºÓïÒå·ÖÎöÓëÖмä´úÂëÉú³É
} }; std::vector
Lexical.cpp #include \#include
sourceCode = s; std::cout << \ << std::endl; return false; source.push_back(ide); identifier.push_back(number); number = 0; } } else if (sourceCode[i] >= '0'&& sourceCode[i] <= '9') { } else { } if (number != NULL) { } switch (sourceCode[i]) { case '+': } source.push_back(add); break; source.push_back(sub); break; source.push_back(mul); break; source.push_back(div); break; source.push_back(pow); break; source.push_back(lef); break; source.push_back(rig); break; std::cout << \ << sourceCode[i] << return false; break; source.push_back(ide); identifier.push_back(number); number = 0; number = number * 10 + sourceCode[i] - 48; case '-': case '*': case '/': case '^': case '(': case ')': default: std::endl; source.push_back(sha); µÚ6Ò³ ¹²15Ò³
} return true; void Lexical::printSource() { } char Lexical::toChar(int a) { } void Lexical::setSourceCode(std::string source) { } sourceCode = source; switch (a) { case add: } return 0; return '+'; return '-'; return '*'; return '/'; return '^'; return 'i'; return '('; return ')'; return '#'; break; case sub: case mul: case div: case pow: case ide: case lef: case rig: case sha: default: for (int i = 0; i < source.size(); i++) { } std::cout << \; std::cout << toChar(source[i]);
µÚ7Ò³ ¹²15Ò³
Syntax.h #pragma once #include \namespace ccyg { std::vector
class Syntax : public ccyg::Lexical { public: enum Relation //¶¨ÒåÓÅÏȹØÏµÃ¶¾Ù { }; enum Symbol { }; Syntax(std::string = 0); ~Syntax(); bool reduced();//¶¨Òå¹éÔ¼·½·¨ void movein();//¶¨ÒåÒÆ½ø·½·¨ int findOperator();//²éÕÒ×î½üÔËËã·û char toChar(int); bool nextStep(); void initNext(); void printSymbol(); void printSemantic(); bool getSuccess(); E = 9, T = 10, F = 11, P = 12 equal = 0, less = 1, greater = 2, //´íÎó i_i = 3, i_left = 4, left_sharp = 5, right_i = 6, right_left = 7, sharp_right = 8
¹²·ÖÏí92ƪÏà¹ØÎĵµ