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

    #include<stdio.h>
    #include <ctype.h>
    #define ok 1
    #define error 0
    #define MAXREGLUARLONG 40
    #define MAXSTATELONG 40
    #define MAXCAHRSLONG 40
    typedef int state;
    int iCurrentState=0; //初态以1开始
    int iPreState=0;
    int iLastForkState=0;
    int iForkState=0;
    int iMaxState=0;
    char cRegluarSting[MAXREGLUARLONG]; //输入的正规式字符串
    char cCharSet[MAXCAHRSLONG]; //字符集
    int iStateMatrix[MAXSTATELONG][MAXCAHRSLONG]; //状态转换矩阵
    state vStoreRegluarSting()//把字符串读入一个缓冲区中
    {
    scanf("%s",cRegluarSting);
    return ok;
    }
    state vPreProcessRegluarSting()
    //对字符串进行预处理,去掉字符串里面的对分析不产生影响
    {
    int i=0;
    while(cRegluarSting[i]!='')
    {
    if(cRegluarSting[i]=='*')
    {
    int j=i+1;
    while(cRegluarSting[j-1]!='')
    {
    cRegluarSting[j-1]=cRegluarSting[j++];
    }
    }
    i++;
    }
    return ok;
    }
    void vConstructStateMatrix(char cChar,int istate)//构造状态转换矩阵
    {
    int i;
    for(i=0;cCharSet[i]!='';i++)
    if(cChar==cCharSet[i])
    break;
    cCharSet[i]=cChar;
    iStateMatrix[iPreState][i]=istate;
    }
    void vAanalyseRegluarSting()//对字符串进行从左到右的分析与处理
    {
    int i=0;
    for(i=0;cRegluarSting[i]!=0;i++)
    {
    if(cRegluarSting[i]=='(') //NFA出现开始分叉情况
    {
    int iTheFirstl=0;
    int iCharNumBeforl=0;
    iForkState=iCurrentState;
    while(cRegluarSting[i]!=')')
    {
    i++;
    if(isalpha(cRegluarSting[i]))
    {
    if(cRegluarSting[i+1]==')')
    iCurrentState=iLastForkState;
    else
    iCurrentState++;
    iCharNumBeforl++; vConstructStateMatrix(cRegluarSting[i],iCurrentState);
    iPreState=iCurrentState;
    if(iCurrentState>iMaxState)
    iMaxState=iCurrentState;
    }
    if(cRegluarSting[i]=='|')
    {
    iPreState=iForkState;
    if(iTheFirstl==0)
    {
    iLastForkState=iCurrentState;
    iTheFirstl++;
    }
    if(iCharNumBeforl==1&&cRegluarSting[i+2]=='|')
    iCurrentState=iForkState;
    iCharNumBeforl=0;
    }
    if(cRegluarSting[i]==')')
    {
    iPreState=iForkState=iLastForkState;
    iCurrentState=iMaxState;
    }
    }
    }
    else
    {
    if(isalpha(cRegluarSting[i]))
    {
    iCurrentState++; vConstructStateMatrix(cRegluarSting[i],iCurrentState);
    iPreState=iCurrentState;
    if(iCurrentState>iMaxState)
    iMaxState=iCurrentState;
    }
    }
    }
    }
    void vPrintfStateProjectFunction()
    {
    int icCharSetPointer;
    int iPreStatePointer;
    for
    (iPreStatePointer=0;iPreStatePointer<MAXSTATELONG;iPreStatePointer++)
    for(icCharSetPointer=0;icCharSetPointer<MAXSTATELONG;icCharSetPointer++)
    if(iStateMatrix[iPreStatePointer][icCharSetPointer]>0) printf("&(%d,%c)=%d ",iPreStatePointer,cCharSet[icCharSetPointer],iStateMatrix[iPreStatePointer][icCharSetPointer]);
    }
    void vPrintfNfa()//输出NFA
    {
    int iStateNumble;
    int i=0;
    printf("NFA的形式为:(S,$,&,S0,F) 以下为NFA的具体集合内容: ");
    printf("字符集$为:{");
    while(cCharSet[i]!=0)
    if(cCharSet[i+1]==0)
    printf("%c",cCharSet[i++]);
    else
    printf("%c,",cCharSet[i++]);
    printf("} ");
    printf(" 状态集S为:{");
    for (i=0;i<=iMaxState;i++) {
    if(i==iMaxState)
    printf("%d",i);
    else
    printf("%d,",i);
    }
    printf("} ");
    vPrintfStateProjectFunction();
    printf(" 初态集S0为:{0} ");
    printf("终态集F为:{%d}",iMaxState);
    }
    void main()
    {
    vStoreRegluarSting();
    vPreProcessRegluarSting();
    vAanalyseRegluarSting();
    vPrintfNfa();
    }

  • 相关阅读:
    泛型技巧系列:如何提供类型参数之间的转换
    一些支离破碎的泛型反射技巧
    泛型技巧系列:类型字典和Type Traits
    Excel开发:简化工作表中选定区域的操作。
    趣味程序:打印自己代码的程序
    VBF BETA 1.5 发布了
    .NET 2.0 CER学习笔记
    随笔乱入,开心就好
    Cocos2dx for WindowsPhone:开发一个打地鼠游戏(下)
    跨平台网络游戏趋势和优势
  • 原文地址:https://www.cnblogs.com/xinmingwang/p/5051808.html
Copyright © 2011-2022 走看看