用C++实现SLR语法分析程序

 更新时间:2022年02月07日 09:19:05   作者:newlw  
大家好,本篇文章主要讲的是用C++实现SLR语法分析程序,感兴趣的同学赶紧来看一看吧,对你有帮助的话记得收藏一下

一、文法

原文法

E->E+T|E-T|T 
T->T*F|T/F|F 
F->id|(E)|num 
其中: id: a-f, A-F,num:0-9 

拓广文法

(0)S->E 
(1)E->E+T    (2)E->E-T    (3)E->T 
(4)T->T*F    (5)T->T/F    (6)T->F 
(7)F->i      (8)F->(E)    (9)F->n 
其中:i:id, n:num

二、SLR 分析表

在这里插入图片描述

三、运行环境

CodeBlocks-13.12 with GCC compiler from TDM-GCC (4.7.1, 32 bit)

四、输入输出设计

输入:文件“fin.txt”输入待分析串

输出:SLR 分析过程输出至“fout.txt”

五、主要数据结构

// 拓广文法的产生式 
vector<string> G;        
// 文法符号到下标的转换字典 
map<char, int> index;    
// SLR action 表
vector<vector<int> > action;    
// SLR goto 表 
vector<vector<int> > goTo;      

六、核心算法

int main() 
{ 
    从文件 fin.txt 读取待分析串到 s; 
    s末尾加‘$'; 
    状态栈 vector<int> statusStack; 
    符号栈 vector<char> symbolStack; 
    状态栈 0;符号栈压‘$';
    ip 指向 s 的第一个字符; 
    do{ 
        top 是栈顶符号; 
        cur 是 ip 所指向的输入符号; 
        if(cur 是字母) cur = ‘i'; 
        if(cur 是数字) cur = ‘n'; 
        x = top 对应下标;
        y = cur 对应下标; 
        动作 val = action[x][y]; 
        if(val == acc){ 
            输出 acc;
            break;
        } 
        else if(val 为 shift){ 
            输出 shift;
            当前输入符号 cur 压入符号栈; 
            动作 val 压入状态栈; 
        } 
        else if(val 为 reduce){ 
            len = reduce 产生式右部长度;
            状态栈和符号栈各弹出 len 个; 
            topS = 当前状态栈栈顶;
            curA = 产生式左部非终结符号; 
            x = topS 对应下标;
            y = curA 对应下标;
            curA 压入符号栈;
            goto[x][y]压入状态栈;
            输出 reduce 产生式; 
        } 
        else{ 
            error;
            break;
        } 
    }while(true);
} 

七、测试

在这里插入图片描述

到此这篇关于用C++实现SLR语法分析程序的文章就介绍到这了,更多相关C++实现SLR语法分析内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • C++ string和wstring相互转换方式

    C++ string和wstring相互转换方式

    这篇文章主要介绍了C++ string和wstring相互转换方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • C++使用read()和write()读写二进制文件

    C++使用read()和write()读写二进制文件

    以文本形式读写文件和以二进制形式读写文件的区别,并掌握了用重载的 >> 和 << 运算符实现以文本形式读写文件,在此基础上,本节将讲解如何以二进制形式读写文件
    2023-10-10
  • 使用OpenCV检测图像中的矩形

    使用OpenCV检测图像中的矩形

    这篇文章主要为大家详细介绍了使用OpenCV检测图像中的矩形,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • C/C++实现动态数组的示例详解

    C/C++实现动态数组的示例详解

    动态数组相比于静态数组具有更大的灵活性,因为其大小可以在运行时根据程序的需要动态地进行分配和调整,本文为大家介绍了C++实现动态数组的方法,需要的可以参考下
    2023-08-08
  • Linux线程管理必备:解析互斥量与条件变量的详解

    Linux线程管理必备:解析互斥量与条件变量的详解

    本篇文章是对互斥量与条件变量的应用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C/C++中typedef的用法大全

    C/C++中typedef的用法大全

    typedef用法一共七种,分别是:为基本数据类型起别名、为结构体起别名、为指针类型起别名、为数组类型起别名、为枚举类型起别名、为模版函数起别名。本文就来分别讲讲这7个用法的具体实现吧
    2023-04-04
  • C++实现线性代数矩阵行简化

    C++实现线性代数矩阵行简化

    这篇文章主要为大家详细介绍了C++实现线性代数矩阵行简化,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-02-02
  • 详解C++如何高效利用CPU缓存

    详解C++如何高效利用CPU缓存

    高效利用CPU缓存是编写高性能C++代码的关键之一,所以这篇文章小编主要来和大家介绍一下C++如何实现高效利用CPU缓存,需要的可以参考一下
    2024-02-02
  • opencv提取水平与垂直线条

    opencv提取水平与垂直线条

    这篇文章主要为大家详细介绍了opencv提取水平与垂直线条,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • C++实现LeetCode(47.全排列之二)

    C++实现LeetCode(47.全排列之二)

    这篇文章主要介绍了C++实现LeetCode(47.全排列之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07

最新评论