Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> C++

C++ में सुपर अग्ली नंबर


nth सुपर बदसूरत संख्या को खोजने के लिए हमें एक फ़ंक्शन बनाना होगा। सुपर बदसूरत संख्याएं सकारात्मक संख्याएं हैं जिनके सभी अभाज्य गुणनखंड k आकार की दी गई अभाज्य सूची में हैं। तो अगर n 12 है और अभाज्य संख्या [2, 7, 13, 19] है, तो आउटपुट 32 होगा, ऐसा इसलिए है क्योंकि [1, 2, 4, 7, 8, 13, 14, 16, 19, 26, 28, 32] 12 सुपर बदसूरत संख्याओं का क्रम है।

इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -

  • num, prime और idx के साथ डेटा स्ट्रक्चर ट्रिपलेट बनाएं

  • अगर n 1 है, तो 1 लौटाएं, n + 1 आकार की एक सरणी बनाएं और इसे 1 से भरें

  • प्राथमिकता कतार pq परिभाषित करें

  • मैं के लिए 0 से लेकर अभाज्य संख्याओं के आकार तक-

    • ट्रिपल बनाएं t(primes[i], primes[i], 2)

  • मेरे लिए 2 से n की सीमा में

    • curr :=pq का टॉप एलिमेंट, फिर pq से डिलीट करें

    • वैल:=करंट की संख्या

    • v[i] :=वैल

    • curr की संख्या:=curr का अभाज्य * v[कर्र का सूचकांक]

    • करी के सूचकांक को 1 से बढ़ाएं

    • pq में curr डालें

    • जबकि वैल =पीक्यू टॉप की संख्या,

      • curr :=pq के ऊपर और pq से हटाएं

      • curr की संख्या:=curr का अभाज्य * v[कर्र का सूचकांक]

      • करी के सूचकांक को 1 से बढ़ाएं

      • pq में curr डालें

  • वापसी v[n]

उदाहरण (C++)

आइए एक बेहतर समझ प्राप्त करने के लिए निम्नलिखित कार्यान्वयन देखें -

#include <bits/stdc++.h>
using namespace std;
struct Data{
   int num, prime, idx;
   Data(int a, int b, int c){
      num = a;
      prime = b;
      idx = c;
   }
};
struct Comparator{
   bool operator()(Data a, Data b){
      return !(a.num < b.num);
   }
};
class Solution {
   public:
   int nthSuperUglyNumber(int n, vector<int>& primes) {
      if(n == 1)return 1;
      vector <int> v(n + 1, 1);
      priority_queue < Data, vector < Data >, Comparator > pq;
      for(int i = 0; i < primes.size(); i++){
         pq.push(Data(primes[i], primes[i], 2));
      }
      int x;
      for(int i = 2; i <= n; i++){
         Data curr = pq.top();
         pq.pop();
         int val = curr.num;
         v[i] = val;
         curr.num = curr.prime * v[curr.idx];
         curr.idx++;
         pq.push(curr);
         while(val == pq.top().num){
            curr = pq.top();
            pq.pop();
            curr.num = curr.prime * v[curr.idx];
            curr.idx++;
            pq.push(curr);
         }
      }
      return v[n];
   }
};
main(){
   Solution ob;
   vector<int> v = {2,7,13,19};
   cout << (ob.nthSuperUglyNumber(12, v));
}

इनपुट

12
[2,7,13,19]

आउटपुट

32

  1. C++ में मितव्ययी संख्या

    इस समस्या में, हमें एक धनात्मक पूर्णांक N दिया जाता है। हमारा कार्य यह जाँचने के लिए एक प्रोग्राम बनाना है कि दी गई संख्या मितव्ययी संख्या है या नहीं। मितव्ययी संख्या - एक संख्या जिसके अंकों की संख्या दी गई संख्या के अभाज्य गुणनखंड में अंकों की संख्या से अधिक है। उदाहरण − 625, संख्या 625 का अभाज्

  1. सी++ पेंटाटोप नंबर

    पास्कल के त्रिभुज में एक पंचकोण संख्या को पाँचवीं संख्या के रूप में वर्णित किया गया है। अब, जैसा कि आप जानते हैं, यह पांचवीं संख्या है, तो इसका मतलब है कि हमारे पास पास्कल के त्रिकोण में कम से कम पांच संख्याएं होनी चाहिए, इसलिए इस श्रृंखला की पहली संख्या 1 4 6 4 1 से शुरू होती है। पास्कल त्रिभुज की

  1. सी ++ में बदसूरत संख्या

    कुरूप संख्याएँ वे संख्याएँ हैं जिनके अभाज्य गुणनखंड 2, 3 या 5 हैं। 1 से 15 तक 11 कुरूप संख्याएँ 1, 2, 3, 4, 5, 6, 8, 9, 10, 12, 15 हैं। संख्याएँ 7 , 11, 13 बदसूरत नहीं हैं क्योंकि वे अभाज्य हैं। 14 नंबर बदसूरत नहीं है क्योंकि इसके अभाज्य गुणनखंड में 7 आएगा। तो मान लीजिए हम 10वीं बदसूरत संख्या की जां