এখানে আমরা বাউম সুইট সিকোয়েন্স দেখব। এই ক্রমটি একটি বাইনারি ক্রম। যদি একটি সংখ্যা 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