ImageVerifierCode 换一换
格式:DOC , 页数:10 ,大小:92.50KB ,
资源ID:551216      下载积分:6 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/551216.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(编译原理-语法分析实验二.doc)为本站上传会员【Fis****915】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

编译原理-语法分析实验二.doc

1、华北水利水电学院 编译原理 实验报告 2010~2011学年 第 二 学期 xxxx 级 计算机 专业 班级: xxxxx 学号: xxxxx 姓名: xxx 一、实验目的 通过设计、编制、调试一个典型的语法分析程序,实现对词法分析程序所提供的单词序列进行语法检查和结构分析,进一步掌握常用的语法分析方法。 二、实验要求 ⑴ 选择最有代表性的语法分析方法,如LL(1)分析法、算符优先法或LR分析法 ⑵ 选择对各种常见程序语言都用的语法结构,如赋值语句(尤指表达式)作为分析对象,并且与所选语法分析方法要比较贴切

2、 ⑶ 实习时间为6小时。 三、实验内容 选题1:使用预测分析法(LL(1)分析法)实现语法分析: (1)根据给定文法,先求出first集合、follow集合和select集合,构造预测分析表(要求预测分析表输出到屏幕或者输出到文件); (2)根据算法和预测分析表分析给定表达式是否是该文法识别的正确的算术表达式(要求输出归约过程) (3)给定表达式文法为: G(E): S→TE E→+TE | T→FK K→*FK | F→(S)|i (4)分析的句子为: (i+i)*i和i+i

3、)*i 四、程序源代码 #include "stdafx.h" #include "SyntaxAnalysis.h" #include "SyntaxAnalysisDlg.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////// CAboutDlg dialog used for App About class CAboutDl

4、g : public CDialog { public: CAboutDlg(); // Dialog Data //{{AFX_DATA(CAboutDlg) enum { IDD = IDD_ABOUTBOX }; //}}AFX_DATA // ClassWizard generated virtual function overrides //{{AFX_VIRTUAL(CAboutDlg) protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV s

5、upport //}}AFX_VIRTUAL // Implementation protected: //{{AFX_MSG(CAboutDlg) //}}AFX_MSG DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD) { //{{AFX_DATA_INIT(CAboutDlg) //}}AFX_DATA_INIT } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialog

6、DoDataExchange(pDX); //{{AFX_DATA_MAP(CAboutDlg) //}}AFX_DATA_MAP } BEGIN_MESSAGE_MAP(CAboutDlg, CDialog) //{{AFX_MSG_MAP(CAboutDlg) // No message handlers //}}AFX_MSG_MAP END_MESSAGE_MAP() // CSyntaxAnalysisDlg dialog CSyntaxAnalysisDlg::CSyntaxAnalysisDlg(CWnd* pParent /*=N

7、ULL*/) : CDialog(CSyntaxAnalysisDlg::IDD, pParent) { //{{AFX_DATA_INIT(CSyntaxAnalysisDlg) m_strCode = _T(""); m_strResult = _T(""); //}}AFX_DATA_INIT // Note that LoadIcon does not require a subsequent DestroyIcon in Win32 m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CS

8、yntaxAnalysisDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(CSyntaxAnalysisDlg) DDX_Control(pDX, IDC_LIST1, m_ListCtrl); DDX_Text(pDX, IDC_EDIT_Code, m_strCode); DDX_Text(pDX, IDC_EDIT_Result, m_strResult); //}}AFX_DATA_MAP } BEGIN_MESSAGE_M

9、AP(CSyntaxAnalysisDlg, CDialog) //{{AFX_MSG_MAP(CSyntaxAnalysisDlg) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_BN_CLICKED(IDC_BTN_Analysis, OnBTNAnalysis) //}}AFX_MSG_MAP END_MESSAGE_MAP() // CSyntaxAnalysisDlg message handlers BOOL CSyntaxAnalysisDlg::OnInitDialog(

10、) { CDialog::OnInitDialog(); ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX); ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE); if (pSysMenu != NULL) { CString strAboutMenu; strAboutMenu.LoadString(IDS_ABOUTBOX); if (!strAboutMenu.IsEmpty()) {

11、 pSysMenu->AppendMenu(MF_SEPARATOR); pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu); } } SetIcon(m_hIcon, TRUE); // Set big icon SetIcon(m_hIcon, FALSE); // Set small icon // TODO: Add extra initialization here //初始化给定文法 m_VN[0]="S"; m_VN[1]="E"; m_VN[2

12、]="T"; m_VN[3]="K"; m_VN[4]="F"; m_VT[0]="i"; m_VT[1]="+"; m_VT[2]="*"; m_VT[3]="("; m_VT[4]=")"; m_Gl[0]=0;m_Gr[0]="TE"; m_Gl[1]=1;m_Gr[1]="+TE"; m_Gl[2]=1;m_Gr[2]="ε"; m_Gl[3]=2;m_Gr[3]="FK"; m_Gl[4]=3;m_Gr[4]="*FK"; m_Gl[5]=3;m_Gr[5]="ε"; m_Gl[6]=4;m_Gr[6]="(S)"; m_G

13、l[7]=4;m_Gr[7]="i"; Cal_Symbol(); Cal_First(); Cal_Follow(); DrawMList(); return TRUE; // return TRUE unless you set the focus to a control } void CSyntaxAnalysisDlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbo

14、ut.DoModal(); } else { CDialog::OnSysCommand(nID, lParam); } } void CSyntaxAnalysisDlg::OnPaint() { if (IsIconic()) { CPaintDC dc(this); SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0); // Center icon in client rectangle int cxIcon = GetSystemMetrics(S

15、M_CXICON); int cyIcon = GetSystemMetrics(SM_CYICON); CRect rect; GetClientRect(&rect); int x = (rect.Width() - cxIcon + 1) / 2; int y = (rect.Height() - cyIcon + 1) / 2; // Draw the icon dc.DrawIcon(x, y, m_hIcon); } else { CDialog::OnPaint(); } } CSyntaxAnalysi

16、sDlg::OnQueryDragIcon() { return (HCURSOR) m_hIcon; } void CSyntaxAnalysisDlg::Cal_Symbol() //求出能推出ε的非终结符 { int i,j,k,nEnd;CString Gr[8]; for (i=0;i<5;i++) m_nFlags[i]=0; //置初值,0表示否 for (i=0;i<8;i++) { Gr[i]=m_Gr[i]; if (Gr[i]=="ε") { m_nFlags[m_Gl[i]]=1; //1表示是,即能推出ε

17、 } } do { nEnd=0; for (i=0;i<5;i++) //检查每一个非终结符 { if (m_nFlags[i]==1) //如果该非终结符能推出ε,就将所有表达式右部删去该终结符 { for (j=0;j<8;j++) //查找每一个表达式 { if (Gr[j].IsEmpty()||Gr[j]=="ε") continue; for (k=0;k

18、etAt(k)==m_VN[i]) //找到该终结符 { Gr[j]=Gr[j].Left(k)+Gr[j].Right(Gr[j].GetLength()-k-1); //删去该终结符 nEnd=1; break; } } if (Gr[j].IsEmpty()) m_nFlags[m_Gl[j]]=1; //如果右部为空,就在表中填是 } } } } while(nEnd); } void CSyntaxAnalysisDlg::Cal_Fir

19、st() //求各非终结符的First集合 { int i,j,k,nEnd,n;CString strFirst; for (i=0;i<5;i++) { for (j=0;j<6;j++) m_First[i][j]=0; } for (i=0;i<8;i++) { if (m_Gr[i].Left(2)=="ε") { m_First[m_Gl[i]][5]=1; continue; } strFirst=m_Gr[i].GetAt(0); for (j=0;j<5;j++) { if (

20、strFirst==m_VT[j]) //如果右部第一个字符是终结符 { m_First[m_Gl[i]][j]=1; break; } } } do { nEnd=0; for (i=0;i<8;i++) { n=0; strFirst=m_Gr[i].GetAt(0); do { for (j=0;j<5;j++) { if (strFirst==m_VN[j]) //如果右部第一个字符是非终结符 { for (k=0;k<6

21、k++) { if (m_First[m_Gl[i]][k]!=m_First[j][k]) { m_First[m_Gl[i]][k]=m_First[j][k]; nEnd=1; } } if (m_First[j][5]==1&&n

22、strFirst=""; break; } } if (j==5) break; } while(!strFirst.IsEmpty()); } } while(nEnd); } void CSyntaxAnalysisDlg::Cal_Follow() //求各非终结符的Follow集合 { } void CSyntaxAnalysisDlg::DrawMList() //构造预测分析表 { int i,j; for (i=0;i<5;i++) { for (j=0;j<6;j++)

23、 { m_M[i][j]=""; } } m_M[0][0]="TE";m_M[0][3]="TE"; m_M[1][1]="+TE";m_M[1][4]="ε";m_M[1][5]="ε"; m_M[2][0]="FK";m_M[2][3]="FK"; m_M[3][1]="ε";m_M[3][2]="*FK";m_M[3][4]="ε";m_M[3][5]="ε"; m_M[4][0]="i";m_M[4][3]="(S)"; m_ListCtrl.SetExtendedStyle(LVS_EX_GRIDLINES); m_ListCtrl

24、InsertColumn(0,"",LVCFMT_CENTER,50); m_ListCtrl.InsertColumn(1,"i",LVCFMT_CENTER,50); m_ListCtrl.InsertColumn(2,"+",LVCFMT_CENTER,50); m_ListCtrl.InsertColumn(3,"*",LVCFMT_CENTER,50); m_ListCtrl.InsertColumn(4,"(",LVCFMT_CENTER,50); m_ListCtrl.InsertColumn(5,")",LVCFMT_CENTER,50); m_Lis

25、tCtrl.InsertColumn(6,"#",LVCFMT_CENTER,50); for (i=0;i<5;i++) { m_ListCtrl.InsertItem(i,m_VN[i]); for (j=0;j<6;j++) { if (!m_M[i][j].IsEmpty()) m_ListCtrl.SetItemText(i,j+1,"→"+m_M[i][j]); } } } void CSyntaxAnalysisDlg::OnBTNAnalysis() { UpdateData(true); if (m_

26、strCode.IsEmpty()) { MessageBox("请输入要分析的句子!","提醒"); return; } if (Analysis()) m_strResult+="归约过程如下:\r\n\r\n"+m_sPro.Right(m_sPro.GetLength()-3); UpdateData(false); } //主要的程序算法 BOOL CSyntaxAnalysisDlg::Analysis() { CString stack[100];int pStack; //定义一个顺序栈 stack[0]="#";stack

27、[1]="S";pStack=1; //初始化栈 int n=0;CString sStack,sCode,str,strCode,strPro; int i,j; strCode=m_strCode+"#"; //输入串 m_sPro="<= S";strPro="S"; while (1) { if (n==m_strCode.GetLength()&&pStack==0) //分析成功 { m_strResult="符合给定文法."; return true; } sStack=stack[pStack]; //栈顶字符

28、 sCode=strCode.GetAt(n); //剩余输入串的首字符 if (sStack==sCode) //匹配 { pStack--; n++; continue; } for (i=0;i<5;i++) { if (sStack==m_VN[i]) break; } if (i==5) { m_strResult="不符合给定文法!"; return false; } for (j=0;j<5;j++) { if (sCode==m_VT[j])

29、 break; } if (j==5&&sCode!="#") { m_strResult="不可识别的字符: "+sCode; return false; } str=m_M[i][j]; if (str.IsEmpty()) { m_strResult="不符合给定文法!"; return false; } if (str=="ε") { strPro=strPro.Left(n)+strPro.Right(strPro.GetLength()-n-1); m_sPro="

30、<= "+strPro+"\r\n"+m_sPro; pStack--; continue; } strPro=strPro.Left(n)+str+strPro.Right(strPro.GetLength()-n-1); m_sPro="<= "+strPro+"\r\n"+m_sPro; pStack--; for (j=0;j

31、结果 分析句子(i+i)*i正确并写出归约 此次实验我继续使用VC++6.0平台编译程序,见面力求简洁,以满足实验功能为主。 输入句子i+i)*i时候 程序判断 不符合给定文法 进行报错。 当输入(i+i)*i@ 时候出现 不合法的字符@ 程序就会报错。 六、小结(不少于100字) 这是第二次编译原理的实验;其主要目的是通过通过设计、编制、调试一个典型的语法分析程序,实现对词法分析程序所提供的单词序列进行语法检查和结构分析,进一步掌握常用的语法分析方法。加深对课堂教学的理解,深刻理解语法分析的整个过程,提高语法分析方法的实践能力。经历过第一次的词法分析之后,我决定本

32、次实验继续采用VC++6.0的编译平台;在保持自己编程风格的简洁、朴实的前提下, 尽我所能追求完善程序的界面。 在编写过程中遇到的主要问题就是如何正确分析first集合、follow集合和select集合,构造预测分析表;另外一个难点就是根据算法和预测分析表分析给定表达式是否是该文法识别的正确的算术表达式。在要求程序能够完成以上的功能的同时,正确报告出错类型和错误位置着实很费力气。在编写过程中我的主要精力在于这两项功能的算法实现;最后经过查阅资料和向同学讨论商量使得问题得到了最终的解决。 概括来讲,这一次语法分析程序很有的难度(比第一次的词法分析难一些), 但是有了上一次实验的经验可以遵循,编写过程倒也还顺利;关键的难题在于将 编译原理课程所学的知识与实际编程操作有机的结合起来。我也通过这次实验得到了这方面的锻炼。在今后的学习中,在课余时间还需要经常加以练习才可以得到更好的提高和更深层次的理解。在此基础上可以根据自己的兴趣 多做课外的延伸和练习。

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服