কম্পিউটার

n বিট সেট সহ k-বিট সংখ্যার সমস্ত সংমিশ্রণ খুঁজুন যেখানে 1 <=n <=k C++ এ সাজানো ক্রমে


ধরুন আমাদের একটি সংখ্যা k আছে। n সেট-বিটের সাথে k-বিট সংখ্যার সম্ভাব্য সকল সমন্বয় খুঁজুন যেখানে 1 <=n <=k। ফলস্বরূপ আমরা প্রথমে একটি সেট বিট সহ সমস্ত সংখ্যা প্রিন্ট করব, তারপরে দুটি বিট সেট সহ সংখ্যাগুলি, সমস্ত বিট সেট করা সংখ্যা পর্যন্ত। যদি দুটি সংখ্যার একই সংখ্যক সেট বিট থাকে, তাহলে ছোট সংখ্যাটি প্রথমে আসে। সুতরাং k =3 হলে, সংখ্যা হবে [001, 010, 100, 011, 101, 110, 111]

এখানে আমরা n সেট-বিটের সাথে k-বিট সংখ্যার সম্ভাব্য সকল সমন্বয় খুঁজে পেতে ডায়নামিক প্রোগ্রামিং পদ্ধতি ব্যবহার করব যেখানে 1 <=n <=k। এই সমস্যাটিকেও দুই ভাগে ভাগ করা যায়। আমরা k দৈর্ঘ্যের সমস্ত সংমিশ্রণ খুঁজে পাব যেখানে 1s-এর n সংখ্যা 0-এর উপসর্গ দিয়ে k – 1 দৈর্ঘ্যের সমস্ত সংমিশ্রণে n-এর সাথে এবং 1-এর দৈর্ঘ্য k – 1-এর সাথে n – 1-এর সাথে।

উদাহরণ

#include<iostream>
#include<vector>
#define K 16
using namespace std;
vector<string> table[K][K];
void getCombinations(int k) {
   string str = "";
   for (int bit = 0; bit <= k; bit++) {
      table[bit][0].push_back(str);
      str = str + "0";
   }
   for (int bit = 1; bit <= k; bit++) {
      for (int n = 1; n <= bit; n++) {
         for (string str : table[bit - 1][n])
            table[bit][n].push_back("0" + str);
         for (string str : table[bit - 1][n - 1])
            table[bit][n].push_back("1" + str);
      }
   }
   for (int n = 1; n <= k; n++) {
      for (string str : table[k][n])
      cout << str << " ";
      cout << endl;
   }
}
int main() {
   int k = 4;
   getCombinations(k);
}

আউটপুট

0001 0010 0100 1000
0011 0101 0110 1001 1010 1100
0111 1011 1101 1110
1111

  1. n বিট সেট সহ k-বিট সংখ্যার সমস্ত সংমিশ্রণ খুঁজুন যেখানে 1 <=n <=k C++ এ সাজানো ক্রমে

  2. C++ এ প্রদত্ত সেটের সমস্ত স্বতন্ত্র উপসেট খুঁজুন

  3. C++ এ n এর থেকে কম বা সমান সমস্ত ফ্যাক্টরিয়াল সংখ্যা খুঁজুন

  4. S-এর মধ্যকের সবচেয়ে কাছাকাছি k সংখ্যা খুঁজে বের করার জন্য C++ প্রোগ্রাম, যেখানে S হল n সংখ্যার একটি সেট