এই নিবন্ধে, আমরা প্যাটার্ন অনুসন্ধানের জন্য Finite Automata অ্যালগরিদম চালানোর জন্য একটি প্রোগ্রাম নিয়ে আলোচনা করব৷
আমরা একটি পাঠ্য [0...n-1] এবং একটি প্যাটার্ন [0...m-1] প্রদান করি। আমাদের টেক্সটে[] প্যাটার্নের সমস্ত ঘটনা খুঁজে বের করতে হবে।
এর জন্য আমরা টেক্সট [] প্রিপ্রসেস করব এবং এটিকে উপস্থাপন করার জন্য একটি 2-ডি অ্যারে তৈরি করব। এর পরে আমাদের কেবল পাঠ্যের উপাদানগুলি এবং স্বয়ংক্রিয়তার বিভিন্ন অবস্থার মধ্যে যেতে হবে৷
উদাহরণ
#include<stdio.h> #include<string.h> #define total_chars 256 int calc_nextstate(char *pat, int M, int state, int x) { if (state < M && x == pat[state]) return state+1; int ns, i; for (ns = state; ns > 0; ns--) { if (pat[ns-1] == x) { for (i = 0; i < ns-1; i++) if (pat[i] != pat[state-ns+1+i]) break; if (i == ns-1) return ns; } } return 0; } //builds Finite Automata void calc_TF(char *pat, int M, int TF[][total_chars]) { int state, x; for (state = 0; state <= M; ++state) for (x = 0; x < total_chars; ++x) TF[state][x] = calc_nextstate(pat, M, state, x); } //prints all occurrences of pattern in text void calc_occur(char *pat, char *txt) { int M = strlen(pat); int N = strlen(txt); int TF[M+1][total_chars]; calc_TF(pat, M, TF); int i, state=0; for (i = 0; i < N; i++){ state = TF[state][txt[i]]; if (state == M) printf ("\n Given pattern is found at the index%d",i-M+1); } } int main() { char *txt = "AABCDAABBDCAABADAABDABAABA"; char *pat = "AABA"; calc_occur(pat, txt); return 0; }
আউটপুট
Given pattern is found at the index 11 Given pattern is found at the index 22