हम एक संख्या N हैं। लक्ष्य 0 और N के बीच की संख्याओं को खोजना है जिनका OR N के साथ N के साथ XOR के बराबर है।
हम इसे नंबर ट्रैवर्स करके करेंगे। i=0 से i<=N तक और प्रत्येक i के लिए, यदि (N^i==i | N) तो इंक्रीमेंट काउंट।
आइए उदाहरणों से समझते हैं।
इनपुट -एक्स=6
आउटपुट - संख्याओं की संख्या जिनके OR N के साथ ==XOR N के साथ:2
स्पष्टीकरण - संख्याएं 0 हैं 1.
इनपुट -एक्स=20
आउटपुट − उन संख्याओं की संख्या जिनके OR N के साथ ==XOR N के साथ:8
स्पष्टीकरण - संख्याएं 0 1 2 3 8 9 10 11
. हैंनीचे दिए गए प्रोग्राम में इस्तेमाल किया गया तरीका इस प्रकार है
-
हम पूर्णांक N लेते हैं।
-
फ़ंक्शन orisXOR(int n) n लेता है और उन संख्याओं की गिनती देता है जिनके OR n के साथ n के साथ XOR के बराबर है।
-
प्रारंभिक गणना 0 के रूप में लें।
-
i=0 से i<=n.
. तक ट्रैवर्स -
अगर मैं|एन==मैं^एन। वेतन वृद्धि की संख्या
-
लूप के अंत में गिनती का वांछित परिणाम होगा।
-
वापसी की गिनती और प्रिंट करें।
उदाहरण
#include <bits/stdc++.h> #include <math.h> using namespace std; int orisXOR(int n){ int count = 0; for (int i = 0; i <= n; i++){ if((n|i)==(i^n)) { count++; } } return count; } int main(){ int N = 15; int nums=orisXOR(N); cout <<endl<<"Count of numbers whose OR with N == XOR with N: "<<nums; return 0; }
आउटपुट
यदि हम उपरोक्त कोड चलाते हैं तो यह निम्न आउटपुट उत्पन्न करेगा -
Count of numbers whose OR with N == XOR with N: 1