怎么用递归下降法求表达式的值?

ming_311 2018-08-09 12:14:27
按照文法推导,使用递归下降法计算一个算术表达式的值,结果不对,看看怎么改
我的文法如下

E→E+T|E-T|T
T→T*F| T/F|F
F→(E)|i

我的代码如下

#include<stdio.h>
#include<string>
using namespace std;
int pos = 0;
string str = "1+2*3-4";
double E();
double T();
double F();

int main() {
double v = E();
printf("%f", v);
getchar();
return 0;
}

double E() {
double v = 0;
char c = str.at(pos);
if (c == '+') {
pos++;
v = E() + T();
}
else if (c == '+') {
pos++;
v = E() - T();
}
else {
pos++;
v = T();
}
return v;
}

double T() {
double v = 0;
char c = str.at(pos);
if (c == '*') {
pos++;
v = T() * F();
}
else if (c == '/') {
pos++;
v = T() / F();
}
else {
pos++;
v = F();
}
return v;
}

double F() {
char c = str.at(pos);
if (c == '(') {
pos++;
double v = E();
c = str.at(pos);
if (c == ')') {
pos++;
return v;
}
}
else {
string s = "";
while (true) {
c = str.at(pos);
if (c >= '0' && c <= '9') {
s += c;
pos++;
}
else {
break;
}
}

return atoi(s.c_str());
}
return 0;
}

...全文
154 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
CyberLogix 2018-08-09
  • 打赏
  • 举报
回复
一步一步调试吧,这个是唯一有效办法
ChongQingJin28 2018-08-09
  • 打赏
  • 举报
回复
有本书叫 flex与bison
赵4老师 2018-08-09
  • 打赏
  • 举报
回复
LEX+YACC
FLEX+BISON

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧