ধরুন, আমাদের একটি পূর্ণসংখ্যা N আছে, আমাদের N দৈর্ঘ্যের সম্ভাব্য সমস্ত স্বতন্ত্র বাইনারি স্ট্রিংগুলির সংখ্যা খুঁজে বের করতে হবে, যার অন্তত তিনটি পরপর 1s আছে। তাই যদি n =4 হয়, তাহলে সংখ্যাগুলো হবে 0111, 1110, 1111, সুতরাং আউটপুট হবে 3।
এটি সমাধান করার জন্য, আমরা ডায়নামিক প্রোগ্রামিং পদ্ধতি ব্যবহার করতে পারি। সুতরাং DP(i, x) i + 1 থেকে i + x অবস্থানে x ধারাবাহিক 1s সহ দৈর্ঘ্য i এর স্ট্রিংগুলির সংখ্যা নির্দেশ করে। তাহলে পুনরাবৃত্তি সম্পর্ক −
এর মত হবেDP(i, x) =DP(i – 1, 0) + DP(i – 1, x + 1)।
পুনরাবৃত্তিটি এই সত্যের উপর ভিত্তি করে যে স্ট্রিংটির i অবস্থানে 0 বা 1 থাকতে পারে।
- যদি ith সূচকে 0 থাকে, তাহলে x =0 এর (i – 1)তম অবস্থানের মান
- যদি ith সূচকে 1 থাকে, তাহলে x এর (i – 1) তম অবস্থানের মান =1 + i অবস্থানে x এর মান
উদাহরণ
#include<iostream>
using namespace std;
int n;
int numberCount(int i, int x, int table[][4]) {
if (i < 0)
return x == 3;
if (table[i][x] != -1)
return table[i][x];
table[i][x] = numberCount(i - 1, 0, table);
table[i][x] += numberCount(i - 1, x + 1, table);
return table[i][x];
}
int main() {
n = 4;
int table[n][4];
for (int i = 0; i < n; i++)
for (int j = 0; j < 4; j++)
table[i][j] = -1;
for (int i = 0; i < n; i++) {
table[i][3] = (1 << (i + 1));
}
cout << "The number of binary strings with at least 3 consecutive 1s: " << numberCount(n - 1, 0, table);
} আউটপুট
The number of binary strings with at least 3 consecutive 1s: 3