我正在尝试编写一个使用Lex/Yacc计算NAND布尔表达式的程序。
例如,如果输入是"true nand (false nand true)“,我的程序应该打印"false”
这就是我到目前为止所拥有的,但我真的被卡住了
我遗漏了什么或做错了什么?
boolean.l
%{
#include "y.tab.h"
%}
%%
"true"|"false" {return BOOL;}
"nand" {return NAND;}
[()] {return yytext[0];}
%%
boolean.y
%token BOOL NAND
%left NAND
%%
boolexp: boolexp NAND boolterm {$$ = !($1 && $3);}
| boolterm {$$=$1;}
;
boolterm: '(' boolexp ')'
| BOOL {$$ = (strcmp($1, "true")) ? 1 : 0;}
;
%%
#include <lex.yy.c>
int main(void) {
yyparse();
}
发布于 2014-03-04 03:33:33
如果您将TRUE
和FALSE
作为两个不同的标记,您会轻松得多。
%token TRUE FALSE NAND
%left NAND
%%
boolexp: boolexp NAND boolterm {$$ = !($1 && $3);}
| boolterm {$$=$1;}
;
boolterm: '(' boolexp ')' {$$ = $2;}
| bool {$$ = $1;}
;
bool: TRUE {$$ = 1;}
| FALSE ($$ = 0;}
;
https://stackoverflow.com/questions/22154353
复制相似问题