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

बाइनरी सरणी पर क्वेरी ऑपरेशन को संसाधित करने के लिए सी ++ कोड

मान लीजिए कि हमारे पास n तत्वों के साथ एक सरणी A है और q प्रश्नों के साथ Q प्रश्नों की एक अन्य सूची है। प्रत्येक क्वेरी [i] में एक जोड़ी (x, k) होती है। जब हम किसी क्वेरी को संसाधित करते हैं, तो x के लिए:A[x] के मान को 1. से कम करें। k के लिए, kth सबसे बड़ा तत्व प्रिंट करें। प्रारंभ में A में सभी तत्व या तो 0 या 1 होते हैं।

इसलिए, यदि इनपुट ए =[1, 1, 0, 1, 0] जैसा है; क्यू =[[2, 3], [1, 2], [2, 3], [2, 1], [2, 5]], तो आउटपुट [1, 1, 1, 0] होगा।>

कदम

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

n := size of A
m := 0
for initialize i := 0, when i < n, update (increase i by 1), do:
   if A[i] is non-zero, then:
      (increase m by 1)
for initialize j := 0, when j < size of Q, update (increase j by 1),
do:
   x := Q[j, 0]
   k := Q[j, 1]
   if x is same as 0, then:
      if A[k] is non-zero, then:
         (decrease m by 1)
      Otherwise
         (increase m by 1)
      A[k] := A[k] XOR 1
   Otherwise
      if m >= k, then:
         print 1
      Otherwise
         print 0

उदाहरण

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

#include bits/stdc++.h>
using namespace std;
void solve(vector<int> A, vector<vector<int>> Q){
   int n = A.size();
   int m = 0;
   for (int i = 0; i < n; i++){
      if (A[i])
      m++;
   }
   for (int j = 0; j < Q.size(); j++){
      int x = Q[j][0];
      int k = Q[j][1];
      if (x == 0){
         if (A[k])
            m--;
         else
            m++;
         A[k] ^= 1;
      }
      else{
         if (m >= k)
            cout << 1 << ", ";
         else
            cout << 0 << ", ";
      }
   }
}
int main(){
   vector<int> A = { 1, 1, 0, 1, 0 };
   vector<vector<int>> Q = { { 1, 2 }, { 0, 1 }, { 1, 2 }, { 1, 0 },{ 1, 4 } };
   solve(A, Q);
}

इनपुट

{ 1, 1, 0, 1, 0 }, { { 1, 2 }, { 0, 1 }, { 1, 2 }, { 1, 0 }, { 1, 4 }}

आउटपुट

1, 1, 1, 0,

  1. सी ++ में ऐरे कार्यान्वयन के साथ बाइनरी ट्री

    एक बाइनरी ट्री एक विशेष प्रकार का पेड़ है जिसमें पेड़ के प्रत्येक नोड में अधिकतम दो चाइल्ड नोड हो सकते हैं। इन चाइल्ड नोड्स को राइट चाइल्ड और लेफ्ट चाइल्ड के रूप में जाना जाता है। एक साधारण बाइनरी ट्री है - पेड़ों का प्रतिनिधित्व करने के दो तरीके हैं, गतिशील नोड प्रतिनिधित्व जो लिंक की गई सूची

  1. सी ++ स्ट्रिंग्स की सरणी

    इस खंड में हम देखेंगे कि C++ में स्ट्रिंग्स की एक सरणी को कैसे परिभाषित किया जाए। जैसा कि हम जानते हैं कि सी में कोई तार नहीं था। हमें कैरेक्टर ऐरे का उपयोग करके स्ट्रिंग्स बनाना है। इसलिए स्ट्रिंग्स की कुछ सरणी बनाने के लिए, हमें वर्णों की एक 2-आयामी सरणी बनानी होगी। प्रत्येक पंक्तियाँ उस मैट्रिक्स

  1. सी++ में छँटाई

    इस खंड में हम देखेंगे कि C++ में सॉर्टिंग एल्गोरिथम कैसे किया जाता है। एक क्रमबद्ध सरणी एक सरणी है जिसमें प्रत्येक तत्व को किसी क्रम में क्रमबद्ध किया जाता है जैसे संख्यात्मक, वर्णानुक्रम आदि। संख्यात्मक सरणी को सॉर्ट करने के लिए कई एल्गोरिदम हैं जैसे कि बबलसॉर्ट, इंसर्शन सॉर्ट, सेलेक्शन सॉर्ट, मर्ज