The Euclidean Algorithm | यूक्लिडियन एल्गोरिद्म
यूक्लिडियन एल्गोरिद्म (The Euclidean Algorithm)
परिचय
यूक्लिडियन एल्गोरिद्म (Euclidean Algorithm) संख्या सिद्धांत (Number Theory) का एक अत्यंत प्राचीन और शक्तिशाली एल्गोरिद्म है, जिसका उपयोग दो पूर्णांकों के महत्तम समापवर्तक (Greatest Common Divisor - GCD) को निकालने के लिए किया जाता है। यह एल्गोरिद्म लगभग 2300 वर्ष पुराना है और सबसे पहले यूनानी गणितज्ञ यूक्लिड (Euclid) द्वारा उनकी प्रसिद्ध पुस्तक “Elements” में प्रस्तुत किया गया था।
यूक्लिडियन एल्गोरिद्म गणित और कंप्यूटर विज्ञान दोनों में अत्यधिक महत्वपूर्ण है क्योंकि यह GCD को निकालने का सबसे तेज़, प्रभावी और तार्किक तरीका प्रदान करता है। आज भी यह एल्गोरिद्म क्रिप्टोग्राफी, डेटा साइंस, और मॉड्यूलर अंकगणित (Modular Arithmetic) में उपयोग किया जाता है।
मुख्य विचार
यूक्लिडियन एल्गोरिद्म इस सरल सिद्धांत पर आधारित है:
यदि a और b दो पूर्णांक हैं (a > b), तो GCD(a, b) = GCD(b, a mod b)
इसका अर्थ यह है कि किसी दो संख्याओं का GCD वही रहता है, चाहे बड़ी संख्या को छोटी संख्या से विभाजित करने पर जो शेष बचे, उसके साथ फिर से प्रक्रिया दोहराई जाए।
प्रक्रिया
- यदि a और b दो धनात्मक पूर्णांक हैं और a > b, तो a को b से भाग दें।
- शेषफल (Remainder) r प्राप्त करें।
- अब GCD(a, b) = GCD(b, r)।
- इस प्रक्रिया को तब तक दोहराएँ जब तक r = 0 न हो जाए।
- अंतिम गैर-शून्य (non-zero) remainder GCD होगा।
उदाहरण 1
GCD(60, 36) निकालने के लिए:
60 = 36 × 1 + 24 36 = 24 × 1 + 12 24 = 12 × 2 + 0 → GCD = 12
इस प्रकार, 60 और 36 का महत्तम समापवर्तक 12 है।
उदाहरण 2
GCD(270, 192) निकालें:
270 = 192 × 1 + 78 192 = 78 × 2 + 36 78 = 36 × 2 + 6 36 = 6 × 6 + 0 → GCD = 6
एल्गोरिद्म का छद्म-कोड (Pseudocode)
function GCD(a, b):
while b ≠ 0:
temp = b
b = a mod b
a = temp
return a
समय जटिलता (Time Complexity)
यूक्लिडियन एल्गोरिद्म की समय जटिलता O(log(min(a, b))) होती है, जो इसे अत्यंत तेज़ बनाती है — बड़े अंकों के लिए भी। यह क्रिप्टोग्राफी जैसे RSA एल्गोरिद्म में बहुत उपयोगी है जहाँ बहुत बड़ी संख्याओं के साथ गणना करनी पड़ती है।
विस्तारित यूक्लिडियन एल्गोरिद्म (Extended Euclidean Algorithm)
विस्तारित संस्करण का उपयोग उन संख्याओं x और y को खोजने के लिए किया जाता है जो इस समीकरण को संतुष्ट करते हैं:
a×x + b×y = GCD(a, b)
यह समीकरण Bézout's Identity कहलाती है और मॉड्यूलर इनवर्स (Modular Inverse) की गणना में बहुत महत्वपूर्ण है। उदाहरण के लिए, क्रिप्टोग्राफी में Modular Multiplicative Inverse निकालने के लिए इसका उपयोग होता है।
डेटा साइंस और कंप्यूटर विज्ञान में उपयोग
- RSA Encryption Algorithm में सहाभाज्य संख्याएँ खोजने के लिए।
- मॉड्यूलर अंकगणित में Modular Inverse निकालने के लिए।
- अल्गोरिद्मिक ऑप्टिमाइजेशन और Recursive Programming के अध्ययन में।
- Data Reduction या Scaling Operations में सामान्य अनुपात निकालने के लिए।
गुणधर्म (Properties)
- GCD(a, b) = GCD(b, a mod b)
- यदि b | a ⇒ GCD(a, b) = b
- GCD(a, b) = GCD(b, a – b)
- यदि GCD(a, b) = 1, तो (a, b) Coprime कहलाते हैं।
निष्कर्ष
यूक्लिडियन एल्गोरिद्म संख्या सिद्धांत की आधारशिला है। यह सरल नियमों पर आधारित होते हुए भी अत्यधिक कुशल (Efficient) और व्यावहारिक है। डेटा साइंस, क्रिप्टोग्राफी, और गणनात्मक गणित में यह एल्गोरिद्म आज भी एक अनिवार्य उपकरण के रूप में प्रयुक्त होता है।
Related Post
- Concept and Formulation of Hypothesis Testing | परिकल्पना परीक्षण की अवधारणा और निर्माण
- Type I and Type II Errors in Hypothesis Testing | परिकल्पना परीक्षण में प्रकार I और प्रकार II त्रुटियाँ
- Neyman–Pearson Lemma in Hypothesis Testing | परिकल्पना परीक्षण में नेयमन–पियर्सन प्रमेय
- Procedures of Hypothesis Testing | परिकल्पना परीक्षण की प्रक्रिया
- Basics of Time Series Analysis and Forecasting | समय श्रेणी विश्लेषण और पूर्वानुमान के मूल सिद्धांत
- Stationarity in Time Series | समय श्रेणी में स्थिरता
- ARIMA Models: Identification, Estimation, and Forecasting | ARIMA मॉडल: पहचान, अनुमान और पूर्वानुमान
- Comparison between Parametric and Non-Parametric Inference | पैरामीट्रिक और नॉन-पैरामीट्रिक अनुमान की तुलना
- Use of Order Statistics | ऑर्डर सांख्यिकी का उपयोग
- Sign Test in Non-Parametric Inference | नॉन-पैरामीट्रिक अनुमान में साइन परीक्षण
- Wilcoxon Signed Rank Test | विल्कॉक्सन साइन रैंक परीक्षण
- Mann–Whitney U Test | मैन–व्हिटनी यू परीक्षण
- Run Test in Non-Parametric Inference | नॉन-पैरामीट्रिक अनुमान में रन परीक्षण
- Kolmogorov–Smirnov Test | कोल्मोगोरोव–स्मिरनोव परीक्षण
- Spearman’s Rank Correlation Test | स्पीयरमैन रैंक सहसंबंध परीक्षण
- Kendall’s Rank Correlation Test | केंडल रैंक सहसंबंध परीक्षण
- Tolerance Region in Statistics | सांख्यिकी में सहनीय क्षेत्र
- Greatest Common Divisors (GCD) | महत्तम समापवर्तक (GCD)
- The Euclidean Algorithm | यूक्लिडियन एल्गोरिद्म
- The Fundamental Theorem of Arithmetic | अंकगणित का मौलिक प्रमेय
- Factorization of Integers and Fermat Numbers | पूर्णांकों का गुणनखंडन और फर्मा संख्याएँ
- Introduction to Congruences | समांगता का परिचय
- Linear Congruences | रेखीय समांगताएँ
- The Chinese Remainder Theorem | चीनी शेष प्रमेय
- Systems of Linear Congruences | रेखीय समांग समीकरणों की प्रणाली
- Introduction to Stochastic Processes | आकस्मिक प्रक्रियाओं का परिचय
- Markov Process | मार्कोव प्रक्रिया
- Transition Probability and Transition Probability Matrix | संक्रमण प्रायिकता और संक्रमण प्रायिकता मैट्रिक्स
- First Order and Higher Order Markov Processes | प्रथम और उच्च क्रम की मार्कोव प्रक्रियाएँ
- n-Step Transition Probabilities | n-चरण संक्रमण प्रायिकताएँ
- Markov Chain | मार्कोव श्रृंखला
- Steady State Condition and Markov Analysis | स्थिर अवस्था की शर्त और मार्कोव विश्लेषण
- Introduction to R | R का परिचय
- Functions in R | R में फ़ंक्शन्स
- Control Flow and Loops in R | R में नियंत्रण प्रवाह और लूप्स
- Working with Vectors and Matrices in R | R में वेक्टर और मैट्रिक्स के साथ कार्य करना
- Reading Data in R | R में डेटा पढ़ना
- Writing Data in R | R में डेटा लिखना
- Working with and Manipulating Data in R | R में डेटा पर कार्य करना और उसे संशोधित करना
- Simulation in R | R में सिमुलेशन
- Linear Model in R | R में रैखिक मॉडल
- Data Frame in R | R में डेटा फ़्रेम