কম্পিউটার

সি প্রোগ্রামে বাউম মিষ্টি সিকোয়েন্স?


এখানে আমরা বাউম সুইট সিকোয়েন্স দেখব। এই ক্রমটি একটি বাইনারি ক্রম। যদি একটি সংখ্যা n-এর বিজোড় সংখ্যা 0s থাকে, তাহলে nম বিট হবে 0, অন্যথায় nম বিট হবে 1।

আমরা একটি প্রাকৃতিক সংখ্যা n আছে. আমাদের কাজ হল বাউম সুইট সিকোয়েন্সের n-তম শব্দটি খুঁজে বের করা। তাই আমাদের পরীক্ষা করতে হবে যে এটিতে বিজোড় দৈর্ঘ্যের শূন্যের পরপর ব্লক আছে কিনা।

যদি সংখ্যাটি 4 হয় তবে শব্দটি 1 হবে, কারণ 4 হল 100৷ তাই এটিতে দুটি (এমন) শূন্য সংখ্যা রয়েছে৷

অ্যালগরিদম

BaumSweetSeqTerm (G, s) −

begin
   define bit sequence seq of size n
   baum := 1
   len := number of bits in binary of n
   for i in range 0 to len, do
      j := i + 1
      count := 1
      if seq[i] = 0, then
         for j in range i + 1 to len, do
            if seq[j] = 0, then
               increase count
            else
               break
            end if
         done
         if count is odd, then
            baum := 0
         end if
      end if
   done
   return baum
end

উদাহরণ

#include <bits/stdc++.h>
using namespace std;
int BaumSweetSeqTerm(int n) {
   bitset<32> sequence(n); //store bit-wise representation
   int len = 32 - __builtin_clz(n);
   //builtin_clz() function gives number of zeroes present before the first 1
   int baum = 1; // nth term of baum sequence
   for (int i = 0; i < len;) {
      int j = i + 1;
      if (sequence[i] == 0) {
         int count = 1;
         for (j = i + 1; j < len; j++) {
            if (sequence[j] == 0) // counts consecutive zeroes
               count++;
            else
               break;
         }
         if (count % 2 == 1) //check odd or even
            baum = 0;
      }
      i = j;
   }
   return baum;
}
int main() {
   int n = 4;
   cout << BaumSweetSeqTerm(n);
}

আউটপুট

1

  1. পাইথনে গাণিতিক ক্রম থেকে অপসারিত শব্দ খুঁজে বের করার প্রোগ্রাম

  2. পাইথনে সিকোয়েন্স থেকে সর্বাধিক কে-রিপিটিং সাবস্ট্রিং খুঁজে বের করার প্রোগ্রাম

  3. পাইথনে সমতুল্য ফ্রিকোয়েন্সি সহ একটি সিকোয়েন্স খুঁজে বের করার প্রোগ্রাম

  4. পাইথনে দীর্ঘতম ধারাবাহিক অনুক্রমের দৈর্ঘ্য খুঁজে বের করার প্রোগ্রাম