1118有限自动机的识别与构造


  1 #include<stdio.h>
  2 #define Max 100
  3 int flag=0;
  4 struct data
  5 {
  6     int a;
  7     char r;
  8     int b;
  9 };
 10 
 11 typedef struct data Data;
 12 void First(int k,int Mark1[],int arry[]);
 13 void Second(int k,int Mark2[],int arry[]);
 14 void Fird(int k,int Mark3[],int arry[]);
 15 void Fouth(int k,int Mark4[],int arry[]);
 16 void Fifth(int k,int Mark5[],int arry[]);
 17 
 18 main()
 19 {
 20     Data fa[Max];
 21     char ch;
 22     char string[Max];
 23     int Mark1[Max];
 24     int Mark2[Max];
 25     int Mark3[Max];
 26     int Mark4[Max];
 27     int Mark5[Max];
 28     int  arry[Max];
 29     
 30     //int flag=0;
 31     int i=-1,j=0,k=0,m=0,n=0;
 32     int count1=0;
 33     int count2=0;
 34     int count3=0;
 35     int count4=0;
 36     int count5=0;
 37 
 38     printf("请输入正规式:");
 39     do{
 40         i++;
 41         scanf("%c",&ch);
 42         string[i]=ch;
 43     }while(ch!='#');
 44     string[i]='\0';
 45     for(j=0;j<i;j++)
 46     {
 47         if(string[j]=='|')
 48         {
 49             Mark1[count1]=j;
 50             count1++;
 51         }
 52         else if(string[j]=='.')
 53         {
 54             Mark2[count2]=j;
 55             count2++;
 56         }
 57         else if(string[j]=='*')
 58         {
 59             Mark3[count3]=j;
 60             count3++;
 61         }
 62         else if(string[j]=='(')
 63         {
 64             Mark4[count4]=j;
 65             count4++;
 66         }
 67         else if(string[j]==')')
 68         {
 69             Mark5[count5]=j;
 70             count5++;
 71         }
 72 
 73         else
 74             continue;
 75     }
 76 
 77     while(m!=i)
 78     {
 79         for(k=0;k<count1;k++)
 80             First(k,Mark1,arry);
 81         for(k=0;k<count2;k++)
 82             Second(k,Mark2,arry);
 83         for(k=0;k<count3;k++)
 84             Fird(k,Mark3,arry);
 85         for(k=0;k<count4;k++)
 86             Fouth(k,Mark4,arry);
 87         for(k=0;k<count5;k++)
 88             Fifth(k,Mark5,arry);
 89         m++;
 90     }
 91 
 92 
 93     printf("f(%d,%c)=%d\n",fa[i].a,fa[i].b,fa[i].r);
 94 
 95 
 96 
 97     //printf("%s\n",string);
 98     //for(k=0;k<count1;k++)
 99     //printf("%d\n",Mark1[k]);
100 }
101 void First(int k,int Mark1[],int arry[])
102 {
103 
104 
105 }
106 void Second(int k,int Mark2[],int arry[])
107 {
108 
109 
110 }
111 void Fird(int k,int Mark3[],int arry[])
112 {
113 
114 
115 }
116 void Fouth(int k,int Mark4[],int arry[])
117 {
118 
119 
120 }
121 void Fifth(int k,int Mark5[],int arry[])
122 {
123 
124 }


1
#include <string.h> 2 #include <stdio.h> 3 #include <stdlib.h> 4 int main() 5 { 6 char p[30][30]; //存放文法 7 char q[30][30]; 8 int line = 0; 9 int n; 10 int i, j; 11 int count =0; 12 int k,t = 0; 13 int flag = 0; 14 int l,m = 0; 15 char VN[30] = {'\0'}; //存放非终结符号 16 char VT[30] = {'\0'}; //存放终结符号 17 printf("请输入规则个数:"); 18 scanf("%d",&n); 19 line = n; 20 for(i = 0; i < 30; i++) //给字符串数组p、q全部赋值为'\0' 21 for(j=0;j<30;j++) 22 { 23 p[i][j]='\0'; 24 q[i][j]='\0'; 25 } 26 printf("请输入文法:\n"); 27 for(i = 0; i < line; i++) 28 { 29 scanf("%s",p[i]); 30 } //把字符分为终结符号合非终结符号 31 l=0; 32 m=0; 33 for(i = 0;i < line; i++) 34 { 35 for(j = 0;j < 30&&(p[i][j] != '\0');j++) 36 { // 非终结符号放入数组VN中 37 if((p[i][j]<='z' && p[i][j]>='a')||(p[i][j]<='9' && p[i][j]>='0')) 38 { 39 flag = 0; 40 for(t=0; VN[t] != '\0';t++) 41 { 42 if(VN[t] == p[i][j]) 43 { 44 flag = 1; 45 break; 46 } 47 } 48 if(flag == 0) 49 { 50 VN[l] = p[i][j]; 51 l++; 52 } 53 } 54 // 终结符号放入数组VT中 55 if(p[i][j]<='Z' && p[i][j]>='A') 56 { 57 flag = 0; 58 for(t = 0; t<30&&(VT[t] != '\0'); t++) 59 { 60 if(VT[t] == p[i][j]) 61 { 62 flag = 1; 63 break; 64 } 65 } 66 if(flag==0) 67 { 68 VT[m] = p[i][j]; 69 m++; 70 } 71 } 72 } 73 } //把规则右部分分离放入数组q中 74 count = 0; 75 k =0; 76 for(i = 0;i < line;i++) 77 { 78 for(j = 4;j < 30 && (p[i][j] != '\0');j++) 79 { 80 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')) 81 { 82 q[count][k] = p[i][j]; 83 k++; 84 } 85 else 86 { 87 count++; 88 k =0; 89 } 90 } 91 count++; 92 k=0; 93 } //判断是确定的还是非确定的有穷状态自动机并进行前半部分打印 94 //判断依据:q数组中每一行字符串是否相同 95 flag = 0; 96 for(i = 0;i < count i++) 97 { 98 for(j = i+1; j < count j++) 99 { 100 if(strcmp(q[i],q[j]) == 0) 101 { 102 flag = 1; 103 break; 104 } 105 } 106 } 107 if(flag == 1) 108 { 109 printf("是非确定的有穷状态自动机,即NFA\n\n"); 110 printf("构造的有穷状态自动机为:\n"); 111 printf("NFA N =(K,∑,M,{S},{Z})\n"); 112 } 113 else 114 { 115 printf("是确定的有穷状态自动机,即DFA\n\n\n"); 116 printf("构造的有穷状态自动机为:\n"); 117 printf("DFA D=(K,∑,M,{S},{Z})\n"); 118 } 119 printf("其中,\nK = {S"); 120 for(i = 0;i < 30 && (VT[i]!='\0');i++) 121 { 122 printf(",%c",VT[i]); 123 } 124 printf("}\n"); 125 printf("∑={"); 126 for(i = 0;i < 30 && (VN[i]!='\0');i++) 127 { 128 printf("%c",VN[i]); 129 } 130 printf("}\n"); //分离文法; 131 k = 0; 132 count = 0; 133 for(i = 0; i < line; i++) 134 { 135 j = 4; 136 while(p[i][j] != '\0') 137 { 138 if(k < 4) 139 { 140 q[count][k] = p[i][k]; 141 k++; 142 } 143 else 144 { 145 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')) 146 { 147 q[count][k] = p[i][j]; 148 k++; 149 j++; 150 } 151 if(p[i][j] == '|') 152 { 153 count++; 154 k = 0; 155 j++; 156 } 157 } 158 } 159 count++; 160 k=0; 161 } 162 printf("\n"); 163 //打印M后半部分 164 printf("M:\n"); 165 l =0; 166 while(VN[l] != '\0') 167 { 168 printf("M(S,%c)={",VN[l]); 169 for(i = 0; i < 30 i++) 170 { 171 for(j = 4; j<30 && (q[i][j] != '\0');j++) 172 { 173 if(VN[l]==q[i][j]&&(q[i][j+1] == '\0')&&(q[i][j-1] == '=')) 174 printf("%c ",q[i][0]); 175 } 176 } 177 printf("}\t"); 178 l++; 179 } 180 printf("\n"); 181 l = 0; 182 k = 0; 183 while(VT[k] != '\0') 184 { 185 l =0; 186 while(VN[l] != '\0') 187 { 188 printf("M(%c,%c)={",VT[k],VN[l]); 189 for(i = 0; i < 30 i++) 190 { 191 for(j = 4; j<30 && (q[i][j] != '\0');j++) 192 { 193 if(VT[k] == q[i][j] && VN[l] == q[i][j+1]) 194 printf("%c ",q[i][0]); 195 } 196 } 197 printf("}\t"); 198 l++; 199 } 200 k++; 201 printf("\n"); 202 } 203 system("pause"); 204 }


总结:

第一个是自己思考的,接下来不知道怎么弄,虽然做得不好,可是也是经过思考的。第二个是借鉴同学的,用来学习 的。知道利用递归来完成自动机,可是不会算法,只能依稀地写下大概的结构框架。

 

posted @ 2015-12-11 17:45  57容杰龙  阅读(210)  评论(0编辑  收藏  举报