词法分析程序实验

一、词法分析程序的功能

输入一段字符串,从字符串表示的源程序中识别出具有独立意义的单词符号,根据扫描到单词符号的第一个字符的种类,拼出相应的单词符号。

 

二、符号与种别码对照表

单词符号

种别码

单词符号

种别码

begin

1

:

17

if

2

:=

18

then

3

<

20

while

4

<=

21

do

5

<>

22

end

6

>

23

l(l|d)*

10

>=

24

dd*

11

=

25

+

13

;

26

-

14

(

27

*

15

)

28

/

16

#

0

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

三、用文法描述词法规则

<字母>:A→a|b|c|…|X|Y|Z
<数字>:B→0|1|2|…|9
<整数常数>:Z→C|ZC

                   C→0|1|2|...|9
<标识符>: I→X|IX|ID
X→a|b|c|…|X|Y|Z|_

D→0|1|2|...|9
<关键字>: K→const|var|procedure|begin|end|odd|if|then|call|while|do|read|write
<运算符>: Y→+|-|*|/|=|#|<|<=|>|>=|!=
<界符>: J→(|)|,|;|.

 

四、c语言源代码和运行结果截图

#include<stdio.h>
#include<string.h>
#include<math.h>
char prog[80]; 
char token[8]; 
char ch; 
int syn,p,m,n; 
double sum;     
int count;

int isSignal; 

int isDecimal;
double decimal; 
int isExp;  
int index;  
int isNegative; 
double temp;
int temp2;

void scanner();

char *rwtab[6]={"begin","if","then","while","do","end"};

void main()
{
    p=0;
    count=0;
    isDecimal=0;
    index=0;
    printf("请输入字符串:\n");
    do{
        ch=getchar();
        prog[p++]=ch;
    }while(ch!='#'); 

    p=0;
    do{
        scanner(); 
        switch(syn)
        {
        case 11:
            if(isDecimal==0)
            {
                printf("(%2d,%8d)\n",syn,(int)sum);
                break;
            }
            else if(isExp==1)
            {
                printf("(%2d,%10.5e)\n",syn,sum);
                isExp=0;
                isDecimal=0;
                break;
            }
            else if(isDecimal==1)
            {
                printf("(%2d,%8.4f)\n",syn,sum);
                isDecimal=0;
                break;
            }
        case -1:
            printf("input error\n");
            break;
        default:
            printf("(%2d,%8s)\n",syn,token);
        }
    }while(syn!=0);
}

void scanner()
{
    sum=0;
    decimal=0;
    m=0;

    for(n=0;n<8;n++)
        token[n]=NULL;
    ch=prog[p++]; 
    while(ch==' ')  
        ch=prog[p++];

    if(((ch>='a')&&(ch<='z'))||((ch>='A')&&(ch<='Z')))
    {
        while(((ch>='a')&&(ch<='z'))||((ch>='A')&&(ch<='Z'))||((ch>='0')&&(ch<='9')))
        {
            token[m++]=ch;
            ch=prog[p++]; 
        }
        token[m++]='\0';
        p--; 
        syn=10; 

        
        for(n=0;n<6;n++)
            if(strcmp(token,rwtab[n])==0)
            {
                syn=n+1;
                break;
            }
    }

   else    if((ch>='0')&&(ch<='9'))
    {
IsNum:
   if(isSignal==1)
   {
       
   }
        while((ch>='0')&&(ch<='9'))
        {
            sum=sum*10+ch-'0'; 
            ch=prog[p++];
        }
        if(ch=='.')
        {
            isDecimal=1;
            ch=prog[p++];
            while((ch>='0')&&(ch<='9'))
            {
                
                temp=(ch-'0')*pow(0.1,++count);
                decimal=decimal+temp;
                
                ch=prog[p++];
            }
            sum=sum+decimal;
        }
        if(ch=='e'||ch=='E')
        {
            isExp=1;
            ch=prog[p++];
            if(ch=='-')
            {
                isNegative=1;
                ch=prog[p++];
            }
            while((ch>='0')&&(ch<='9'))
            {
                
                index=index*10+ch-'0';
                ch=prog[p++];
            }
            if(isNegative)
                sum=sum*pow(0.1,index);
            else
                sum=sum*pow(10,index);

        }
        if(isSignal==1)
        {
            sum=-sum;
            isSignal=0;
        }
        p--;
        syn=11;
    }

    else switch(ch)
    {
        case '<':
            m=0;
            token[m++]=ch;
            ch=prog[p++];
            if(ch=='>')
            {
                syn=21; 
                token[m++]=ch;
            }
            else if(ch=='=')
            {
                syn=22;
                token[m++]=ch;
            }
            else
            {
                syn=20;
                p--;
            }
            break;

        case '>':
            m=0;
            token[m++]=ch;
            ch=prog[p++];
            if(ch=='=')
            {
                syn=24;
                token[m++]=ch;
            }
            else
            {
                syn=23;
                p--;
            }
            break;

        case ':':
            m=0;
            token[m++]=ch;
            ch=prog[p++];
            if(ch=='=')
            {
                syn=18;
                token[m++]=ch;
            }
            else
            {
                syn=17;
                p--;
            }
            break;

        case '+':
            temp2=prog[p];
            if((temp2>='0')&&(temp2<='9'))
            {
                isSignal=2;
                ch=prog[p++];
                goto IsNum;
            }
            syn=13;
            token[m++]=ch;
            break;
        case '-':
            temp2=prog[p];
            if((temp2>='0')&&(temp2<='9'))
            {
                isSignal=1;
                ch=prog[p++];
                goto IsNum;  
            }
            syn=14;
            token[m++]=ch;
            break;
        case '*':
            syn=15;
            token[m++]=ch;
            break;
        case '/':
            syn=16;
            token[m++]=ch;
            break;
        case '=':
            syn=25;
            token[m++]=ch;
            break;
        case ';':
            syn=26;
            token[m++]=ch;
            break;
        case '(':
            syn=27;
            token[m++]=ch;
            break;
        case ')':
            syn=28;
            token[m++]=ch;
            break;
        case'#':
            syn=0;
            token[m++]=ch;
            break;
        default:
            syn=-1;
    }
}

 

 

转载于:https://www.cnblogs.com/xuyizhu/p/5924490.html

实验一:词法分析 一、实验目的 通过设计一个具体的词法分析程序,加深对词法分析原理的理解。并掌握在对程序设计语言源程序进行扫描过程中将其分解为各类单词词法分析方法。 编制一个单词过程,从输入的源程序中,识别各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。并依次输各个单词的内部编码及单词符号自身值。 二、实验预习提示 1、 词法分析器的功能和输格式 词法分析器的功能是输入源程序,输单词符号词法分析器的单词符号常常表示成以下的二元式(单词种别码,单词符号的属性值)。本实验中,采用的是一类符号对应一个种别码的方式。 2、 单词的BNF表示 ----> ----> ----> + ----> - 等等 3、 模块结构(见课本P95-96)(可根据自己的理解适当修改) 三、实验过程和指导: (一) 准备: 1. 阅读课本有关章节,明确语言的语法,写基本保留字、标识符、常数、运算符、分隔符和程序例。 2. 初步编制好程序。 3. 准备好多组测试数据。 (二) 上机: (三) 程序要求: 1. 要求用C++Builder或者Dephi或者VC、VB等可视化编程工具编写;要求有界面(即一般windows下应用程序界面)。 2. 输入为某语言源代码。 程序输入/输示例: 如源程序为C语言。输入如下一段: main() { int a,b; a=10; b=a+20; } 要求输如下(并以文件形式输)。 (2,”main”) (5,”(“) (5,”)“) (5,”{“} (1,”int”) (2,”a”) (5,”,”) (2,”b”) (5,”;”) (2,”a”) (4,”=”) (3,”10”) (5,”;”) (2,”b”) (4,”=”) (2,”a”) (4,”+”) (3,”20”) (5,”;”) (5,”}“) 注:为右大括号 要求(可根据实际情况加以扩充和修改): 识别保留字:if、int、for、while、do、return、break、continue等等,单词种别码为1。 其他的标识符,单词种别码为2。 常数为无符号数,单词种别码为3。 运算符包括:+、-、*、/、=、>、=、<=、!= ;单词种别码为4。 分隔符包括: “,”“;”“(”“)”“{”“}”等等, 单词种别码为5。 (四) 程序思路(仅供参考): 0. 定义部分:定义常量、变量、数据结构。 1. 初始化:从文件将源程序输入到字符缓冲区中。 2. 取单词前:去掉多余空白。调用过程GETNB(); 3. 提取字符组成单词,利用课本P97图4.5转换图构造单词扫描过程SCAN(),需要根据实际情况加以修改。 4. 判断单词的种别码,调用过程LOOKUP(); 5. 显示(导)结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值