কম্পিউটার

প্যাটার্ন অনুসন্ধানের জন্য সীমাবদ্ধ অটোমেটা অ্যালগরিদমের জন্য C++ প্রোগ্রাম


এই নিবন্ধে, আমরা প্যাটার্ন অনুসন্ধানের জন্য 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

  1. সর্বোত্তম পৃষ্ঠা প্রতিস্থাপন অ্যালগরিদমের জন্য C++ প্রোগ্রাম

  2. C++ এ একটি আয়তক্ষেত্র প্যাটার্ন প্রিন্ট করার জন্য প্রোগ্রাম

  3. অ্যারের উপাদানগুলির গুণনের জন্য C++ প্রোগ্রাম

  4. C++ এ অক্টাল থেকে দশমিক রূপান্তরের জন্য প্রোগ্রাম