C语言之Chomsky文法类型判断

2024-03-23 03:08

本文主要是介绍C语言之Chomsky文法类型判断,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

文法G[S] = {VN,VT,P,S}:

其中VN(非终结符),VT(终结符),P(产生式集),是非空的有限集;

S属于VN,是文法的开始符号;

 

根据产生式集来判断文法的类型:

 

#include<stdio.h>
#include<string.h>#define len 3//0型文法:左侧必须含有非终结符
int zeroJudge(char part[2][10])
{int i = 0;//判断产生式左值是否全为非终结符while(part[0][i] != '\0'){/*if(part[0][i] < 65 || (part[0][i] > 90 && part[0][i] < 97) || part[0][i] > 122){printf("含有非法符号,不合法产生式!\n");return -1;}else*/ if((part[0][i] >= 97 && part[0][i] <= 122)){if(i == (strlen(part[0])-1)){printf("左侧全为终结符,不合法产生式!\n");return 0;}}else if(part[0][i] >= 65 && part[0][i] <= 90){//合法产生式break;}i++;}return 1;
}//1型文法:右侧的字符长度大于等于左侧
int oneJudge(char part[2][10])
{if(strlen(part[1]) >= strlen(part[0])){return 1;}return 0;
}//2型文法:左侧仅含一个非终结符
int twoJudge(char part[2][10])
{if((1 == strlen(part[0])) && (part[0][0] >= 65 && part[0][0] <= 90)){return 1;}return 0;
}//3型文法:产生式必须型如:A->Aa|a或A->aA|a
int threeJudge(char part[2][10])
{if((1 == strlen(part[1])) && (part[1][0] >= 97 && part[1][0] <= 122)){return 1;}if(2 == strlen(part[1])){if((part[1][0] >= 65 && part[1][0] <= 90) && (part[1][1] >= 97 && part[1][1] <= 122)){return 1;}if((part[1][0] >= 97 && part[1][0] <= 122) && (part[1][1] >= 65 && part[1][1] <= 90)){return 1;}}return 0;
}void judge(int flag)
{switch(flag){case 0:printf("0型文法!\n");break;case 1:printf("1型文法!\n");break;case 2:printf("2型文法!\n");break;case 3:printf("3型文法!\n");break;}
}int main()
{char gram[len][20];int i = 0;int j = 0;int m = 0;const char *split = "=";char *p;char part[2][10];int flag = 4;//存储文法while(i < len){scanf("%s",&gram[i]);i++;}//判断文法类型for(j = 0; j < len; j++){//根据"="分割  得到文法产生式的左右两部分p = strtok (gram[j],split);m = 0;while(p!=NULL) {strcpy(part[m],p);m++;//分割下一个产生式p = strtok(NULL,split);}if(zeroJudge(part)){if(oneJudge(part)){if(twoJudge(part)){if(threeJudge(part)){if(flag < 3);elseflag = 3;}else{if(flag < 2);elseflag = 2;}}else{if(flag < 1);elseflag = 1;}}else{flag = 0;}}}judge(flag);return 0;
}

 

这篇关于C语言之Chomsky文法类型判断的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

C语言中的浮点数存储详解

《C语言中的浮点数存储详解》:本文主要介绍C语言中的浮点数存储详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、首先明确一个概念2、接下来,讲解C语言中浮点型数存储的规则2.1、可以将上述公式分为两部分来看2.2、问:十进制小数0.5该如何存储?2.3 浮点