zoukankan      html  css  js  c++  java
  • 构造该正规式自动机

    #include<stdio.h>
    #include <ctype.h>
    #define  ok   1
    #define  error 0
    #define  MAXREGLUARLONG 30
    #define  MAXSTATELONG  30    
    #define  MAXCAHRSLONG   30  
    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();   
    }
    

      

  • 相关阅读:
    再谈应用程序单例运行(只能开启一个进程)
    wpf 无边框窗口 最大化,缩放问题修复
    AutoClose=false的情况下自动关闭下拉框(ToolStripHost)
    C#调用其他语言(如PB)的com组件
    再写Javascript闭包
    Vue 数据双向绑定的误区
    后台数据缓存的一点心得
    C# 使用 Newtonsoft.Json 对DataTable转换中文乱码问题的解决
    第二章 Background & Borders 之 Multiple borders
    第二章 Background & Borders 之 Transparent Border
  • 原文地址:https://www.cnblogs.com/caishun/p/5051802.html
Copyright © 2011-2022 走看看