symbol.c
来自「将简单中缀算术表达式变换成: (1)后缀形式 (2)生成书上描述的抽象堆栈机」· C语言 代码 · 共 37 行
C
37 行
#include "global.h"
#define STRMAX 999
#define SYMMAX 100
char lexemes[STRMAX];
int lastchar = -1;
struct entry symtable[SYMMAX];
int lastentry = 0;
int lookup(s)
char s[];
{
int p;
for(p = lastentry;p>0;p=p-1)
{
if(strcmp(symtable[p].lexptr,s)==0)
return p;
}
return 0;
}
int insert(s,tok)
char s[];
int tok;
{
int len;
len = strlen(s);
if(lastentry +1>=SYMMAX)
error("symbol table full");
if(lastchar+len+1>=STRMAX)
error("lexemes array full");
lastentry =lastentry +1;
symtable[lastentry].token = tok;
symtable[lastentry].lexptr = &lexemes[lastchar +1];
lastchar =lastchar +len +1;
strcpy(symtable[lastentry].lexptr,s);
return lastentry;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?