放下代码,识别尾部以01结尾的0和1的串 自动机NFA实现

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int get_one_char(char *str,int i)
{
    if(*(str+i)=='\0')
        return 3;
    if(*(str+i)=='0')
        return 0;
    if(*(str+i)=='1')
        return 1;
}

void query_table(int a[3],int (*statustable[3][2])[3],int one_zero)
{
    int b[3]={3,3,3};
    int i=0,j;
        for(j=0;i<3;i++){
            if(a[i]!=3){
             for(j=0;j<3;j++){
                if(statustable[a[i]][one_zero]!=NULL){
                    if((b[j]!=*(*statustable[a[i]][one_zero]+j))&&*(*statustable[a[i]][one_zero]+j)!=3)
                        b[j]=*(*statustable[a[i]][one_zero]+j);
                    
                        
                }
                        
            }
        
        }    
        }
    for(i=0;i<3;i++){
        a[i]=b[i];
    }

}

int give_result(int a[3]) 
{
    int i,n=0;
    for(i=0;i<3;i++)
        if(a[i]==2){
            n=1;
        }
    if(n==1)
        return 1;
    else
        return 0;
            
}

int main()
{
    int a[3][3]={{0,1,3},
                 {0,3,3},
                 {3,3,2}
                 };
    int (*(b[3][2]))[3]={{a+0,a+1},
                         {NULL,a+2},
                         {a+2,a+2}
                        };
    
    int statu[3],i,c,m=1,h;
    char str[100];
        
    for(i=0;i<3;i++){
        statu[i]=a[1][i];
        
    }
    scanf("%s",str);
    i=0;    
       while((c=get_one_char(str,i))!=3){
           if(m>1){
               statu[2]=3;
    
           }    
           query_table(statu,b,c);
           if(give_result(statu)){
               m++;
           }
           //for(h=0;h<3;h++)
//               printf("%d",statu[h]);
   //        printf("\n");
           i++;
       }
       if(give_result(statu) )
           printf("yes!\n");
    else
        printf("no!\n");
    
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值