nandgame中的Grammar(语法)

2024-04-11 05:44
文章标签 语法 grammar nandgame

本文主要是介绍nandgame中的Grammar(语法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目说明:

语法定义涉及数字、括号和运算符+-的表达式的语法。起始符号为Expression。一个表达式应该对应于以下之一:一个数字标记Expression + ExpressionExpression - Expression- Expression( Expression )    

level help

通过语法来描述高级语言的语法。语法是一组规则,其中每个规则命名语法的一部分,
并定义了它如何组成。例如,这是一个非常简单的语法,
用于允许两个数字相加,如“2 + 2”:Expression → Number + Number
Number和+是在标记定义阶段定义的标记。
此语法将允许任意两个数字的加法,
但不会允许多次加法,如2 + 3 + 4。
为了支持任意多次加法,我们使用引用自身的规则:Program → Expression 
Expression → Expression + Number 
Expression → Number
此语法将允许无限次加法,
因为+左边的Expression本身可以是加法。**术语**
语法中使用的术语称为符号。
规则定义了一个符号(箭头左侧)
由一个或多个其他符号(箭头右侧)组成。
箭头右侧的符号要么是通过标记规范(在前一步中定义)
定义的标记,
要么是由同一语法中的规则定义的符号本身。代表标记的符号(如Number和+)称为终结符,
像Program和Expression这样由语法中
其他规则定义的符号称为非终结符。用作非终结符号的名称是任意的 - 您可以使用对您有意义的名称。
唯一的条件是必须有一个“起始符号”称为Program,
它表示整个程序。**解析算法**
在这个级别上,我们不编写实际的解析器,
该解析器根据语法规则处理源文本并生成语法树。
解析器算法是计算机科学的一个整个分支,
超出了本游戏的范围。
也就是说,最简单的解析器形式,
递归下降解析器易于编写,并且对于大多数目的而言已经足够了。
如果您想探索编写自己的解析器,这是一个很好的起点。本游戏使用Earley解析器,它不是最快的解析器,
但它灵活且易于编写语法。
Grammar 语法规则
Specify the rules for parsing the token into a syntax tree.
On the left is the name of a production. 
On the right is one or more names of productions or tokens
指定将标记解析为语法树的规则。
左侧是产生式的名称。
右侧是一个或多个产生式或标记的名称。
The syntax tree of the source code parsed by the grammar.
源代码由语法解析生成的语法树。

最终题目期望的答案如下:
在这里插入图片描述
在这里插入图片描述
需要注意的是:
Expression 与 符号 之间,记得加空格。

根据错误提示:
Error when parsing ‘8 + (-4)’. Parse error: Unexpected ‘(’
把 Expression + ( - Expression ) 穷举出来。

这篇关于nandgame中的Grammar(语法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893221

相关文章

C++语法知识点合集:11.模板

文章目录 一、非类型模板参数1.非类型模板参数的基本形式2.指针作为非类型模板参数3.引用作为非类型模板参数4.非类型模板参数的限制和陷阱:5.几个问题 二、模板的特化1.概念2.函数模板特化3.类模板特化(1)全特化(2)偏特化(3)类模板特化应用示例 三、模板分离编译1.概念2.模板的分离编译 模版总结 一、非类型模板参数 模板参数分类类型形参与非类型形参 非类型模板

Java基础回顾系列-第一天-基本语法

基本语法 Java基础回顾系列-第一天-基本语法基础常识人机交互方式常用的DOS命令什么是计算机语言(编程语言) Java语言简介Java程序运行机制Java虚拟机(Java Virtual Machine)垃圾收集机制(Garbage Collection) Java语言的特点面向对象健壮性跨平台性 编写第一个Java程序什么是JDK, JRE下载及安装 JDK配置环境变量 pathHe

Hibernate框架中,使用JDBC语法

/*** 调用存储过程* * @param PRONAME* @return*/public CallableStatement citePro(final String PRONAME){Session session = getCurrentSession();CallableStatement pro = session.doReturningWork(new ReturningWork<C

ORACLE语法-包(package)、存储过程(procedure)、游标(cursor)以及java对Result结果集的处理

陈科肇 示例: 包规范 CREATE OR REPLACE PACKAGE PACK_WMS_YX IS-- Author : CKZ-- Created : 2015/8/28 9:52:29-- Purpose : 同步数据-- Public type declarations,游标 退休订单TYPE retCursor IS REF CURSOR;-- RETURN vi_co_co

ElasticSearch的DSL查询⑤(ES数据聚合、DSL语法数据聚合、RestClient数据聚合)

目录 一、数据聚合 1.1 DSL实现聚合 1.1.1 Bucket聚合  1.1.2 带条件聚合 1.1.3 Metric聚合 1.1.4 总结 2.1 RestClient实现聚合 2.1.1 Bucket聚合 2.1.2 带条件聚合 2.2.3 Metric聚合 一、数据聚合 聚合(aggregations)可以让我们极其方便的实现对数据的统计、分析、运算。例如:

react笔记 8-16 JSX语法 定义数据 数据绑定

1、jsx语法 和vue一样  只能有一个根标签 一行代码写法 return <div>hello world</div> 多行代码返回必须加括号 return (<div><div>hello world</div><div>aaaaaaa</div></div>) 2、定义数据 数据绑定 constructor(){super()this.state={na

python基础语法十一-赋值、浅拷贝、深拷贝

书接上回: python基础语法一-基本数据类型 python基础语法二-多维数据类型 python基础语法三-类 python基础语法四-数据可视化 python基础语法五-函数 python基础语法六-正则匹配 python基础语法七-openpyxl操作Excel python基础语法八-异常 python基础语法九-多进程和多线程 python基础语法十-文件和目录操作

python进阶篇-day07-高级语法与正则

day07-python其他高级语法 一. with(上下文管理) 介绍 概述 一个类只要实现了__ enter __ () 和 __ exit __ ()方法, 这个类就是一个上下文管理器类, 该类的对象 = 上下文管理器对象 目的 节约资源, 提高效率, 避免手动释放资源, 且出bug的时候, 也会自动尝试释放资源 特点 上下文管理器对象, 可以结合with语句使用

javaweb-day01-4(DTD 的语法)

XML 文件中 DOCTYPE 声明语句的格式: XML 文件使用 DOCTYPE 声明语句来指定它所遵循的 DTD 文件。 DOCTYPE声明语句有两种形式: 1.  当引用的约束文件在本地硬盘时,使用如下方式: <!DOCTYPE    xml文档根节点    SYSTEM    "dtd文档在本地的绝对路径或相对路径"> 例如:<!DOCTYPE 书架 SYSTEM "book

javaweb-day01-2(00:17:48 XML 的作用 和 语法)

XML: 描述 可扩展标记语言,w3c  2000年发布的 XML 1.0 版本规范。 用来描述数据之间的关系。 经常用作 软件  的配置文件,描述 模块与模块 之间的关系。 还用作    软件启动  的配置文件,描述 启动模块之间的 依赖 关系。 语法 一个XML文件分为如下几部分内容: 文档声明元素属性注释CDATA区、转义字符处