实验一 词法分析实验

实验一、词法分析实验

一、        实验目的

编制一个词法分析程序

二、        实验内容和要求

输入:源程序字符串

输出:二元组(种别,单词本身)

三、        实验方法、步骤及结果测试

 1.      源程序名:压缩包文件(rarzip)中源程序名×××.c可执行程序名:×××.exe

2.      原理分析及流程图

把输入的字符用链表进行存储,利用自己构造的一个判断函数,读取字符链表中存储的字符并进行判断处理,如果符合条件则输出,并继续判断直到链表为空则退出。

3.     
主要程序段及其解释:

typedef struct link          //字符链表

{

char data;               //存放字符

struct link *next;       //指向下一个

}Link;

void specialchar(Link
*charhead)   //判断字符函数

{

Link *q,*p;

int i;

q=charhead->next;

while(q!=NULL)

{

switch(q->data)

{

case ‘b‘:                       //判断是否是标识符begin

special[0]=q->data;       //把待判断的字符存入数组

q=q->next;

if(q->data==‘e‘)             //如果符合则继续进入判断

{

special[1]=q->data;    //把待判断的字符存入数组

q=q->next;

if(q->data==‘g‘)

{

special[2]=q->data;

q=q->next;

if(q->data==‘i‘)

{

special[3]=q->data;

q=q->next;

if(q->data==‘n‘)

{

special[4]=q->data;            //把符合文法的字符全部存入到一个数组里

printf("<标识符> ");

for(i=0;i<5;i++)                 //用for循环把数组输出

printf("%c",special[i]);

printf("\n");

}

}

}

}

break;

…………….

  1. 4.     
    运行结果及分析

一般必须配运行结果截图,结果是否符合预期及其分析。

   (截图需根据实际,截取有代表性的测试例子)

 

四、       
实验总结

程序能够把题目中给出的关键字begin、 if、 then、 while 、do、 end、 l(l|d)*、dd*,以及加减乘除,小括号,尖括号等于号 等判断出来。

本程序使用的是链表进行存储,原因是链表具有灵活性,能够根据用户的输入情况来申请空间,而且所需的空间灵活,不像数组那样要求申请固定的空间导致空间的浪费。同时本程序也使用大量的判断符,利用数组把待判断的字符进行存储,一旦发现符合我们的文法规则就把数组进行输出。然后重复使用该数组。

不足:进入判断后指针会指向下一个链表元素,当发现不符合这个单词的文法规则的时候就会退出switch循环,而退出switch循环时,会再一次指向下一个链表元素,因此产生,当不符合文法规则的时候,就会少判断到一个字符元素。

 

时间: 2024-08-22 06:25:59

实验一 词法分析实验的相关文章

实验一 词法分析实验报告

实验一.词法分析实验 专业:商业软件工程2班  姓名 别博文  学号201606110175 一. 实验目的        编制一个词法分析程序. 二. 实验内容和要求 对字符串表示的源程序,从左到右进行扫描和分解,根据词法规则,识别出一个一个具有独立意义的单词符号,以供语法分析之用 发现词法错误,则返回出错信息.. 三. 实验方法.步骤及结果测试  源程序名:压缩包文件(rar或zip)中源程序名 ceshi.c 可执行程序名:ceshi.exe 主要程序段及其解释: 实现主要功能的程序段,重

实验一词法分析实验报告

一.        实验目的 (1)    理解词法分析在编译程序中的作用. (2)    加深对有穷自动机模型的理解. (3)    掌握词法分析程序的实现方法. (4)    用C语言对一个简单语言的子集编制一个一遍扫锚的编译理解,掌握编译程序的实现方法和技术. 二.        实验内容和要求 1,待分析的简单语言的词法 2,各种单词符号对应的种别码. 3,词法分析程序的功能(输入,输出). 三.        实验方法.步骤及结果测试 1.      源程序名:压缩包文件(rar或zi

词法分析实验报告(一)

实验一  词法分析实验 专业:商业软件三班   姓名:曾铭杰  学号:201506110197 一.        实验目的 用C语言设计一个词法分析程序,将字符流的源程序进行分析,从左到右逐个字符地扫描源程序,同时滤掉空格符和回车换行符,逐个读取字符,然后将它们拼在一起组成一个有意义的单词符号,识别出单词的种别及单词自身的值. 二.        实验内容和要求 1.输入一段源程序字符串: 2.输出格式按照二元组(种别,单词符号本身). 三.        实验方法.步骤及结果测试 1.   

词法分析实验报告

词法分析实验报告 一.        实验目的 编制一个词法分析器,通过该词法分析程序的设计实例,进一步了解词法分析程序构造的一些细节. 二.        实验内容和要求 实验内容: 对字符串表示的源程序,从左到右进行扫描和分解.根据词法规则,识别出一个一个具有独立意义的单词符号,以供语法分析之用,若发现词法错误,则返回出错信息. 实验要求: 输入:源程序字符串 输出:二元组(种别,单词本身) 待分析语言的词法规则 三. 实验方法.步骤及结果测试 源程序名:压缩包文件(rar或zip)中源程序

实验一词法分析程序

一.        实验目的 编制一个词法分析程序 二.        实验内容和要求 输入:源程序字符串 输出:二元组(种别,单词本身) 待分析语言的词法规则 三.        实验方法.步骤及结果测试 1.      源程序名:压缩包文件(rar或zip)中源程序名 cifafenxi.c  cifafenxi.exe 2.      原理分析及流程图 3.      主要程序段及其解释: do { scanf("%s\n",input); i=0; while(input[i]

实验一词法分析试验报告

实验一.词法分析实验 专业:商业软件工程   姓名:林海鑫  学号:201506110120 一.        实验目的 (1)掌握词法分析程序的实现方法. (2)用C语言对一个简单语言的子集编制一个一遍扫锚的编译理解,掌握编译程序的实现方法和技术. (3)理解词法分析在编译程序中的作用. (4)加深对有穷自动机模型的理解. 二.        实验内容和要求 1,词法分析程序的功能(输入,输出). 2,待分析的简单语言的词法. 3,各种单词符号对应的种别码. 三.        实验方法.步

实验1 词法分析

格式说明:排版时注意按此模板的字体,字号和行距. 报告提交和打印输出时请去掉此框. 实验一.词法分析实验 商软1班   周展鹏  201506110114 一.        实验目的        通过设计一个词法分析程序,对词法进行分析,加强对词法的理解,掌握对程序设计语言的分解和理解. 二.        实验内容和要求 在原程序中输入源代码 对字符串表示的源程序 从左到右进行扫描和分解 根据词法规则 识别出一个一个具有独立意义的单词符号 以供语法分析之用 发现词法错误,则返回出错信息 在

实验一&#160;&#160;词法分析程序045

实验一  词法分析程序实验 专业 计算机科学与技术   姓名 邹汉辉  学号 201508030045 一.实验目的 1. 编制一个词法分析程序 二. 实验内容和要求 1. 输入:源程序字符串 2. 输出:二元组(种别,单词本身) 3. 待分析语言的词法规则 三. 实验方法.步骤及结果测试 1.  源程序名:压缩包文件(rar或zip)中源程序名 cifafenxi.c 可执行程序名:cifafenxi.exe 2.  原理分析及流程图 3.  主要程序段及其解释: #include<stdio

203-陈冠权-词法分析实验报告

实验一.词法分析实验 专业:商业软件工程3班   姓名:陈冠权  学号:201506110203 一.实验目的 通过设计编译程序完成一个词法分析器,加深对词法分析的理解. 二.实验内容和要求 输入一连串的字符,即保留字.标识符.常数.运算符和分隔符,通过词法 分析器来识别具有独立意义的字符,并输出各个字符的内部编码. 三.实验方法.步骤及结果测试 1.   源程序名:词法分析.c 可执行程序名:词法分析.exe 2.      原理分析及流程图 要求在主函数输入字符串,将字符串存入数组里面,调用