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