博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
203-陈冠权
阅读量:5090 次
发布时间:2019-06-13

本文共 1619 字,大约阅读时间需要 5 分钟。

词法分析的功能:在录入一串符号串后,通过与程序中以存在的数组,或者用switch语句进行分析,通过这样来分析词法

符号与种别码对照表:

单词符号

种别码

单词符号

种别码

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

文法描述词法规则:

<标识符>:L|L<字母数字>

<数字>: L|d|L<数字>|<数字>

程序如下:

#include<stdio.h>

#define MAX 100
void cifa(char a[MAX]);
main()
{
    char ch;
    int i=0;
    int *b[6]={"begin","if","then","while","do","end"};
    char a[MAX];
    printf("请输入一个字符串(以@为结束符):");
    do{
        scanf("%c",&ch);
        a[i++]=ch;
    }while(ch!='@');
    cifa(a);
}
void cifa(char a[MAX])
{
    char ch;
    int data[MAX];
    ch=a[MAX];
    switch(ch)
    {
    case '+':
        data[0]=13;
        printf("(%d,%c)",data[0],ch);
        break;
    case '-':
        data[1]=14;
        printf("(%d,%c)",data[1],ch);
        break;
    case '*':
        data[2]=15;
        printf("(%d,%c)",data[2],ch);
        break;
    case '/':
        data[3]=16;
        printf("(%d,%c)",data[3],ch);
        break;
    case ':':
        data[4]=17;
        printf("(%d,%c)",data[4],ch);
        break;
    case ':=':
        data[5]=18;
        printf("(%d,%c)",data[5],ch);
        break;
    case '<':
        data[6]=20;
        printf("(%d,%c)",data[6],ch);
        break;
    case '<=':
        data[7]=21;
        printf("(%d,%c)",data[7],ch);
        break;
    case '<>':
        data[8]=22;
        printf("(%d,%c)",data[8],ch);
        break;
    case '>':
        data[9]=23;
        printf("(%d,%c)",data[9],ch);
        break;
    case '>=':
        data[10]=24;
        printf("(%d,%c)",data[10],ch);
        break;
    case '=':
        data[11]=25;
        printf("(%d,%c)",data[11],ch);
        break;
    case ';':
        data[12]=26;
        printf("(%d,%c)",data[12],ch);
        break;
    case '(':
        data[13]=27;
        printf("(%d,%c)",data[13],ch);
        break;
    case ')':
        data[14]=28;
        printf("(%d,%c)",data[14],ch);
        break;
    case '#':
        data[15]=0;
        printf("(%d,%c)",data[15],ch);
        break;
    default:
        break;
    }
}

转载于:https://www.cnblogs.com/cgq520/p/5924663.html

你可能感兴趣的文章
实验五 Java网络编程及安全
查看>>
32位与64位 兼容编程
查看>>
iframe父子页面通信
查看>>
ambari 大数据安装利器
查看>>
java 上传图片压缩图片
查看>>
magento 自定义订单前缀或订单起始编号
查看>>
ACM_拼接数字
查看>>
计算机基础作业1
查看>>
Ubuntu 深度炼丹环境配置
查看>>
C#中集合ArrayList与Hashtable的使用
查看>>
从一个标准 url 里取出文件的扩展名
查看>>
map基本用法
查看>>
poj-1163 动态规划
查看>>
Golang之interface(多态,类型断言)
查看>>
Redis快速入门
查看>>
BootStrap---2.表格和按钮
查看>>
Linear Algebra lecture 2 note
查看>>
CRC计算模型
查看>>
Ajax之404,200等查询
查看>>
Aizu - 1378 Secret of Chocolate Poles (DP)
查看>>