上下文无关文法的存储与表示C语言

本文介绍了上下文无关文法(CFG)的基础知识,包括其定义和产生式,并以C语言为工具,探讨了如何存储和表示CFG。文章适合初学者阅读,作者诚邀高手指正并分享更优化的代码实现。
摘要由CSDN通过智能技术生成

上下文无关文法(context-free grammar,CFG)

【相关概念】

CFG定义:
  一个四元数组G=(VN,VT,S,P),其中:
  VN:非终结符集合
  VT:终结符集
  S:开始符号
  且VN∩VT=∅,S∈VN
注:
  产生式中→的左边称作产生式的头部,→的右边称作产生式的右部或体。P中产生式的一般形式为A→α|β,其中A∈VN,α,β∈(VN∪VT)*
  通常用大写字母表示非终结符,小写字母表示终结符。

【数据结构】
  C语言

【代码实现】

#include<stdio.h>

#define MaxRightLength 20
#define MaxRuleNumber 20
#define MaxVtNumber 20
#define MaxVnNumber 20

char Vt[MaxVtNumber];//定义终结符集
char Vn[MaxVnNumber];//非终结符

struct rule{
   
	char Left;
	char Right[MaxRightLength];
	int RightLength;
}grammar;//声明结构体类型

int main(){
   
	int number;//文法表达式数目
	int x=0;//非终结符集元素个数
	int y=0;//终结符集元素个数
	printf("请输入表达式数目number:");
	scanf("%d",&number);
	struct rule grammar[MaxRuleNumber];//定义文法
	char xy[2];
	
	for(int i=0; i<number; i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值