#include<string.h>
#include<stdio.h>
#include<stdlib.h>
int main()
{
char p[30][30];//存放文法
char q[30][30];
int line=0;
int n;
int i,j;
int count=0;
int k,t=0;
int flag=0;
int l,m=0;
char VN[30]={'\0'};//存放非终结符号
char VT[30]={'\0'};//存放终结符号
printf("请输入规则个数");
scanf("%d",&n);
line=n;
for(i=0;i<30;i++)//给字符串数组p,q全部赋值为'\0'
for(j=0;j<30;j++)
{
p[i][j]='\0';
q[i][j]='\0';
}
printf("请输入文法:\n");
for(i=0;i<line;i++)
{
scanf("%s",p[i]);
}
//把字符分为终结符和非终结符
l=0;
m=0;
for(i=0;i<line;i++)
{
for(j=0;j<30&&(p[i][j]!='\0');j++) { //非终结符放入数组VN中
if(p[i][j]<='z'&&p[i][j]>='a'||(p[i][j]<='9'&&p[i][j]>='0'))
{
flag=0;
for(t=0;VN[t]!='\0';t++)
{
if(VN[t]==p[i][j])
正规文法转化DFA
最新推荐文章于 2023-10-22 17:31:04 发布
该博客介绍了一个程序,用于将正规文法转化为确定或非确定的有穷状态自动机(DFA或NFA),包括文法规则的输入、非终结符与终结符的分离、以及构造自动机的过程。
摘要由CSDN通过智能技术生成