मान लें कि हमारे पास दो धनात्मक पूर्णांक X और Y के प्रारंभिक मान हैं। X और Y का अंतिम मान ज्ञात कीजिए, जैसे कि नीचे बताए अनुसार कुछ परिवर्तन होगा -
-
चरण 1 - यदि एक्स =0 और वाई =0 तो प्रक्रिया को समाप्त करें, अन्यथा चरण 2 पर जाएं
-
चरण 2 − यदि X>=2Y है, तो X =X – 2Y सेट करें, और चरण 1 पर जाएं, अन्यथा चरण 3 पर जाएं
-
चरण 3 - यदि Y>=2X, तो Y =Y - 2X सेट करें, और चरण 1 पर जाएं, अन्यथा प्रक्रिया समाप्त करें।
संख्या X और Y रेंज [0 और 1018] में होगी, इसलिए हम Brute Force दृष्टिकोण का उपयोग कर सकते हैं।
उदाहरण
#include<iostream> using namespace std; void alterNumber(long long x, long long y) { while (1) { if (x == 0 || y == 0) break; if (x >= 2 * y) x = x % (2 * y); else if (y >= 2 * x) y = y % (2 * x); else break; } cout << "X: " << x << "\n" << "Y: " << y; } int main() { long long x = 12, y = 5; alterNumber(x, y); }
आउटपुट
X: 0 Y: 1