- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
// LR1.cpp : Defines the entry point for the console application.//
#include stdafx.h#include CharStack.h#include IntStack.h#include memory.h#include stdio.h#include stdlib.h#include malloc.h
struct BNFNODE // 产生式节点{char Left;????? // 产生式左部char Right[MAX_DATA_LEN]; // 产生式右部int?? RLen;????? // 产生式右边长度} m_Bnf[MAX_DATA_LEN];int m_nBnfLen;
enum ACTIONTYPE // 动作类别{Push,?? // 移进Sumup,?? // 规约Accept,?? // 接受Error?? // 出错};
struct LR1TABLE{int?? nStatus;?? // 状态char CurChar;?? // 当前符号ACTIONTYPE ActionType; // 动作类别int?? nNextStatus; // 下一状态移进(push)或规约(sumup)产生式序号} m_Lr1[MAX_DATA_LEN];int?? m_nLr1Len;
/****************************************************** 以下是词法分析文件操作******************************************************/// 清空链表void ClearWords(WORDNODE *pHeader){WORDNODE *pNode;
while (pHeader != NULL){?? pNode = pHeader-pNext;?? free(pHeader);?? pHeader = pNode;}}
// 增加结点WORDNODE* AddNode(char c[], WORDNODE *pTail){// c第0个字节为单词类别,第1个为逗号,第2个以后是值
WORDNODE *pNode = (WORDNODE *)malloc(sizeof(WORDNODE));pNode-byType = c[0] - 0;pNode-pNext = NULL;
int nChars = MAX_DATA_LEN - 2;memcpy(pNode-Value, c[2], nChars);
pTail-pNext = pNode;return pNode;}
bool ReadWords(char FileName[], WORDNODE *pHeader){// 打开文件FILE *f = fopen(FileName, r);if (f == NULL){?? ClearWords(pHeader);?? return false;}
WORDNODE *pTail = pHeader;char c[MAX_DATA_LEN];
// 读取数据while (!feof(f)){?? fscanf(f, %s\n, c);?? pTail = AddNode(c, pTail);?? printf(%s\n, c);}
// 关闭文件fclose(f);
// 增加一个结束符c[0] = WT_OPERATOR + 0;c[1] = ,;c[2] = #;c[3] = \0;AddNode(c, pTail);
return true;}
/****************************************************** 以下是文法文件操作******************************************************/char *ReadFile(char FileName[], int *nLen){// 打开文件FILE *f = fopen(FileName, r);if (f == NULL)?? return NULL;
// 读取文件char *pChar = (char *)malloc(sizeof(char) * MAX_DATA_LEN);// 读取数据int nRead;*nLen = 0;while (!feof(f)){?? nRead = fread(pChar + *nLen
您可能关注的文档
- 绩效评估——阿里巴巴.ppt
- 维也纳各地的风景.ppt
- 维多利亚杯校园天使选拔大赛1102.doc
- 维生素C的故事完整版.ppt
- 综合农贸市场管理制度完整版.doc
- 综合办公楼建设项目申请报告.doc
- 综合教程4paraphrase答案终结版.doc
- 综合治理责任方案.doc
- 综合管理部岗位职责及.doc
- 绿化景观投标邀请方案.doc
- 2025AACR十大热门靶点推荐和解读报告52页.docx
- 财务部管理报表.xlsx
- 高中物理新人教版选修3-1课件第二章恒定电流第7节闭合电路欧姆定律.ppt
- 第三单元知识梳理(课件)-三年级语文下册单元复习(部编版).pptx
- 俄罗斯知识点训练课件-七年级地理下学期人教版(2024).pptx
- 课外古诗词诵读龟虽寿-八年级语文上学期课内课件(统编版).pptx
- 高三语文二轮复习课件第七部分实用类文本阅读7.2.1.ppt
- 高考物理人教版一轮复习课件第4章第3讲圆周运动.ppt
- 高考英语一轮复习课件53Lifeinthefuture.ppt
- 2025-2030衣柜行业风险投资发展分析及投资融资策略研究报告.docx
文档评论(0)