编译原理 语法分析.doc

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译原理 语法分析 源程序: #include stdio.h #include stdlib.h #include string.h #define _KEY_WORD_END waiting for your expanding ///////////////////////////////////// void Irparser(); void statement(); void expression(); void term(); void factor(); void yucu(); void nextWord(); static int syn=1,kk=0; static int line=1; /////////////////////////////////////////////实验一 typedef struct { int typenum; char* word; }WORD; char input[255]; char token[255]=; int p_input; int p_token; char ch; char* rwtab[]={begin,if,then,while,do,end,_KEY_WORD_END}; WORD* scaner(); WORD* oneword=new WORD; char m_getch() { ch=input[p_input]; p_input++; return (ch); } void getbc() { if(ch==\n) { line++; } while(ch== ||ch==10) { ch=input[p_input]; p_input++; } } void concat() { token[p_token]=ch; p_token++; token[p_token]=\0; } int letter() { if(ch=ach=z || ch=Ach=Z) return 1; else return 0; } int digit() { if(ch=0ch=9) return 1; else return 0; } /* 检索关键字表格 */ int reserve() { int i=0; while(strcmp(rwtab[i],_KEY_WORD_END)) { if(!strcmp(rwtab[i],token)) return i+1; i++; } return 10; } /* 回退一个字符 */ void retract() { p_input--; } /* 数字转换成二进制,读者自己补全? */ char* dtb() { return NULL; } WORD* scaner() { WORD* myword = new WORD; myword-typenum=10; myword-word=; p_token=0; m_getch(); getbc(); // 注释 if(ch==/) { char ch=m_getch(),ch0=\0; if(ch==/) // 单行注释 { while(ch!=\n) ch=m_getch(); myword-typenum=999; myword-word=ZhuShi; line++; return (myword); } else { retract(); retract(); char ch=m_getch(),ch0=\0; } } /* 注释 */ if(letter()) { while(letter()||digit()) { concat(); m_getch(); } retract(); myword-typenum=reserve(); myword-word=token; return (myword); } else if(digit()) { while(digit()) { concat(); m_getch(); } retract(); myword-typenum=20; myword-word=token; return (myword); } else switch(ch) { case =: m_getch(); if(ch===) { myword-typenu

文档评论(0)

tianma2015 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档