首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C-跳过epsilon产品的递归下降分析器

C-跳过epsilon产品的递归下降分析器
EN

Stack Overflow用户
提问于 2015-07-15 19:16:49
回答 1查看 423关注 0票数 0

构造递归下降解析器来解析以下语法。有没有一种方法,我可以不传递任何东西回来,所有的感光片(E)?(考虑到我所采用的解析方法,如代码所示)

E= TG G= +TG =e T= FH H= *FH =e F= (E) = id

代码语言:javascript
复制
#include <stdio.h>

char* next;

int terminal(char);
int E();int G();int G1();int G2();int T();int H();int H1();int H2();int F();int F1();int F2();

int main(int argc, char const *argv[])
{
    char str[10];
    printf("Enter an expression to be parsed : ");
    scanf("%s", str);
    next = &str[0]
    (*next == '\0' && E() == 1) ? printf("Parsed Successfully\n") : printf("Parsed Unsuccessfully\n");
    return 0;
}

int terminal(char token){return *next++ == token;}
int E(){return T() && G();}
int G(){char* temp = next; return (next = temp, G1()) || (next = temp, G2());}
int G1(){return terminal('+') && T() && G();}
int G2(){return;}   //ERROR : non-void function should return a value
int T(){return F() && H();}
int H(){char* temp = next; return (next = temp, H1()) || (next = temp, H2());}
int H1(){return terminal('*') && F() && H();}
int H2(){return;}   //ERROR : on-void function should return a value
int F(){char* temp = next; return (next = temp, F1()) || (next = temp, F2());}
int F1(){return terminal('(') && E() && terminal(')');}
int F2(){return terminal('a');}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-15 20:34:56

代码不可读。但逻辑表明,您应该返回一个布尔值。空洞的生产总是成功的。所以它应该是真的。例如,

代码语言:javascript
复制
 int H2(){return true;} 

当然,将这些琐碎的产品内联起来也是有意义的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31439165

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档