编译原理 词法分析器的问题

来源:百度知道 编辑:UC知道 时间:2024/06/18 12:24:15
实现PL/0语言的词法分析器,输入源程序,并对其进行扫描和分解,识别出单词符号。
PL/0语言词法规则定义如下:
1、唯一的数据类型是整型;
2、算符和界符有: ’+’, ’-‘, ’*’, ’/’, ’>’, ’>=’, ’<’, ’<=’, ’=’, ’<>’,
’. ‘,’(’,’)’,’,’,’;’,’:=’
3、标识符以字母开头,后跟字母和/或数字组成的字符串;
4、关键字作为保留字,如下所示:const,var,procedure,call,begin,end,if,then,while,do,odd

请各位高手帮忙来讲解一下这个试验主程序

private void buttonStart_Click(object sender, EventArgs e)
{
String s = richTextBox1.Text;
String temp;
try
{
for (int i = 0; i < s.Length; i++)
{
if (s[i] <= 'z' && s[i] >= 'A')
{
int j = i;
while (((s[i] >= 'A' && s[i] <= 'z') || (s[i] >= '0' && s[i] <= '9')) && i < s.Length - 1)
i++;

QQ号给我留一下。我会联系你的。
留言到我百度HI上就可以。

额,有点难。。。
祝你好运

学习

#include <iostream>
#include <vector>
#include <utility>
#include <string>
#include <fstream>
#include <algorithm>
#include <cstdlib>
using namespace std;

//用来存储目标文件名
string file_name;

//提取文本文件中的信息。
string GetText();

//获得一个单词符号,从位置i开始查找。
//并且有一个引用参数j,用来返回这个单词最后一个字符在str的位置。
string GetWord(string str,int i,int& j);

//这个函数用来除去字符串中连续的空格和换行
//第一个参数为目标字符串,第二个参数为开始位置
//返回值为连续的空格和换行后的第一个有效字符在字符串的位置
int DeleteNull(string str,int i);

//判断i当前所指的字符是否为一个分界符,是的话返回真,反之假
bool IsBoundary(string str,int i);

//判断i当前所指的字符是否为一个运算符,是的话返回真,反之假
bool IsOperation(string str,int i);

//此函数将一个pair数组输出到一个文件中
void OutFile(vector<pair<int,string> > v);