第一范文网 - 专业文章范例文档资料分享平台

词法分析器设计实验报告

来源:用户分享 时间:2025/5/31 15:49:44 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

六、实验代码(C#)

using System;

using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text;

using System.Threading.Tasks; using System.Windows.Forms;

namespace LL_1_分析法 {

public partial class Form1 : Form {

public Production []production; public char[] terminator;//终结符 public char[] nonterminal;//非终结符 public int flag = 0;

public String Terminator = \ String STACK = \符号栈 String stack = \输入串 public struct Production { public Char noter;

public String production; }//产生式结构体 public struct FIRST { public Char noter; public String first; }//FIRST集结构体

public struct FOLLOW { public Char noter; public String follow; }//FOLLOW集结构体 public struct PLACE{ public bool flag; public int x; public int y; }

public Form1() {

InitializeComponent(); }

private Char[] getNonterminal(Char[] s) {

String nonterminal = \

for (int i = 0; i < s.Length; i++) {

if (s[i] >= 'A' && s[i] <= 'Z') {

if (!nonterminal.Contains(s[i]))

nonterminal = nonterminal + s[i]; } }

return nonterminal.ToCharArray(); }

private Char[] getTerminator(Char[] s) {

String terminator = \

for (int i = 0; i < s.Length; i++) {

if ((s[i] >= 'a' && s[i] <= 'z') || s[i] == '(' || s[i] == ')' || s[i] == '+' || s[i] == '-' || s[i] == '*' || s[i] == '/'||s[i]=='@') {

if (!terminator.Contains(s[i]))

terminator = terminator + s[i]; } }

Terminator = terminator.Replace(\ return terminator.ToCharArray(); }

private Production[] getProductions(Char[] s) {

int index = 0;

Production[] productions=new Production[20]; for (int i = 0; i < s.Length - 1; i++) {

int flag = 0;

if (nonterminal.Contains(s[i]) && s[i + 1] == '$')//- {

productions[index].noter = s[i]; i = i + 3;

while (s[i] != ' '&&s[i]!='\\n') {

if (flag == 0) {

productions[index].production =productions[index].production +s[i];

i++; } else {

productions[index].noter = productions[index - 1].noter;

productions[index].production = productions[index].production + s[i];

i++; }

if (s[i] == '|') {

flag = 1; index++; i++; }

搜索更多关于: 词法分析器设计实验报告 的文档
词法分析器设计实验报告.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c1dolg1f4jy072ie1ycam_5.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top