zoukankan      html  css  js  c++  java
  • 1118实验三有限自动机的构造与识别

    #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]={''};//存放非终结符号
    char VT[30]={''};//存放终结符号
    printf("请输入规则个数");
    scanf("%d",&n);
    line=n;
    for(i=0;i<30;i++)//给字符串数组p,q全部赋值为''
    for(j=0;j<30;j++)
    {
    p[i][j]='';
    q[i][j]='';
    }
    printf("请输入文法: ");
    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]!='');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]!='';t++)
    {
    if(VN[t]==p[i][j])
    {
    flag=1;break;
    }
    }
    if(flag==0)
    {
    VN[l]=p[i][j];
    l++;
    }
    }
    //终结符放在数组VT中
    if(p[i][j]<='Z'&&p[i][j]>='A')
    {
    flag=0;
    for(t=0;t<30&&(VT[t]!='');t++)
    {
    if(VT[t]==p[i][j])
    {
    flag=1;
    break;
    }
    }
    if(flag==0)
    {
    VT[m]=p[i][j];
    m++;
    }
    }
    }
    }
    //把规则右部分分离,放入数组q中
    count=0;
    k=0;
    for(i=0;i<line;i++)
    {
    for(j=4;j<30&&(p[i][j]!='');j++)
    {
    if((p[i][j]<='z'&&p[i][j]>='a')||(p[i][j]<='Z'&&p[i][j]>='A')||(p[i][j]<='9'&&p[i][j]>='0'))
    {
    q[count][k]=p[i][j];
    k++;
    }
    else
    {
    count++;
    k=0;
    }
    }
    count++;
    k=0;
    }
    //判断是确定的还是非确定的有穷状态自动机,并进行前半部分打印
    //判断依据:q数组中每一行字符串是否相同
    flag=0;
    for(i=0;i<count;i++)
    {
    for(j=i+1;j<count;j++)
    {
    if(strcmp(q[i],q[j])==0)
    {
    flag=1;
    break;
    }
    }
    }
    if(flag==1)
    {
    printf("是非确定的有穷状态自动机,即NFA ");
    printf("构造的有穷状态自动机为: ");
    printf("NFA N=(K,E(总和的意思),M,{S},{Z}) ");
    }
    else
    {
    printf("是确定的有穷状态自动机,即DFA ");
    printf("构造的有穷状态自动机为: ");
    printf("DFA N=(K,E(总和的意思),M,{S},{Z}) ");
    }
    printf("其中, K={S");
    for(i=0;i<30&&(VT!='');i++)
    {
    printf(",%c",VT[i]);
    }
    printf("} ");
    printf("E={");
    for(i=0;i<30&&(VN[i]!='');i++)
    {
    printf("%c ",VN[i]);
    }
    printf("} ");
    //分离文法
    k=0;
    count=0;
    for(i=0;i<line;i++)
    {
    j=4;
    while(p[i][j]!='')
    {
    if(k<4)
    {
    q[count][k]=p[i][k];
    k++;
    }
    else
    {
    if((p[i][j]<='z'&&p[i][j]>='a')||(p[i][j]<='Z'&&p[i][j]>='A')||(p[i][j]<='9'&&p[i][j]>='0'))
    {
    q[count][k]=p[i][j];
    k++;
    j++;
    }
    if(p[i][j]=='l')
    {
    count++;
    k=0;
    j++;
    }
    }
    }
    count++;
    k=0;
    }
    printf(" ");
    //打印M后部分
    printf("M: ");
    l=0;
    while(VN[l]!='')
    {
    printf("M(S,%c)={",VN[l]);
    for(i=0;i<30;i++)
    {
    for(j=4;j<30&&(q[i][j]!='');j++)
    {
    if(VN[l]==q[i][j]&&(q[i][j+1]=='')&&(q[i][j-1]=='='))
    printf("%c",q[i][0]);
    }
    }
    printf("} ");
    l++;
    }
    printf(" ");
    l=0;k=0;
    while(VT[k]!='')
    {
    l=0;
    while(VN[l]!='')
    {
    printf("M(%c,%c)={",VT[k],VN[l]);
    for(i=0;i<30;i++)
    {
    for(j=4;j<30&&(q[i][j]!='');j++)
    {
    if(VT[k]==q[i][j]&&VN[l]==q[i][j+1])
    printf("%c",q[i][0]);
    }
    }
    printf("} ");
    l++;
    }
    k++;
    printf(" ");
    }
    system("pause");
    }

  • 相关阅读:
    Codeforces 834E The Bakery【枚举+数位dp】
    Codeforces 834D The Bakery【dp+线段树维护+lazy】
    Codeforces Round #426 (Div. 2)【A.枚举,B.思维,C,二分+数学】
    暑期英语学习(词组积累)【持续更新中】
    “玲珑杯”ACM比赛 Round #19题解&源码【A,规律,B,二分,C,牛顿迭代法,D,平衡树,E,概率dp】
    关于前端的photoshop初探的学习笔记
    2017 Multi-University Training Contest
    BZOJ 1041: [HAOI2008]圆上的整点【数论,解方程】
    微信公众平台教程,注册申请、认证、开发、推广营销,教你怎么用微信公众号
    微信电视2.0版将新增语音搜索、节目单分享推荐自定义等
  • 原文地址:https://www.cnblogs.com/linfa/p/5038011.html
Copyright © 2011-2022 走看看