पूरक की विधि: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
{{short description|Method of subtraction}} | {{short description|Method of subtraction}} | ||
[[Image:Complement numbering gnangarra.JPG|thumb|जोड़ने वाली मशीन पर संख्याओं का पूरक c. 1910. घटाते समय उपयोग के लिए छोटी संख्याएँ, बड़ी संख्याओं के नौ पूरक हैं, जिनका उपयोग जोड़ते समय किया जाता है।]]गणित और [[ कम्प्यूटिंग ]] में, पूरक की विधि सकारात्मक और नकारात्मक [[पूर्णांक]] | [[Image:Complement numbering gnangarra.JPG|thumb|जोड़ने वाली मशीन पर संख्याओं का पूरक c. 1910. घटाते समय उपयोग के लिए छोटी संख्याएँ, बड़ी संख्याओं के नौ पूरक हैं, जिनका उपयोग जोड़ते समय किया जाता है।]]गणित और [[ कम्प्यूटिंग ]] में, '''पूरक की विधि''' सकारात्मक और नकारात्मक [[पूर्णांक]] की सममित श्रेणी को इस तरह से एन्कोड करने की तकनीक है कि वे पूरी श्रृंखला में जोड़ने के लिए ही [[कलन विधि]] (हार्डवेयर) का उपयोग कर सकते हैं। [[स्थितीय संकेतन]] की दी गई संख्या के लिए संख्याओं के संभावित निरूपण का आधा भाग सकारात्मक संख्याओं को कूटबद्ध करता है, अन्य आधा उनके संबंधित योगात्मक व्युत्क्रमों का प्रतिनिधित्व करता है। परस्पर योगात्मक व्युत्क्रम संख्याओं के युग्मों को ''पूरक'' कहा जाता है। इस प्रकार किसी भी संख्या का [[घटाव]] उसके पूरक को जोड़कर क्रियान्वित किया जाता है। किसी भी संख्या के चिह्न को बदलना उसके पूरक को उत्पन्न करके एन्कोड किया जाता है, जिसे बहुत ही सरल और कुशल एल्गोरिदम द्वारा किया जा सकता है। यह विधि सामान्यतः [[यांत्रिक कैलकुलेटर]] में उपयोग की जाती थी और अभी भी आधुनिक [[कंप्यूटर]] में उपयोग की जाती है। ''रेडिक्स पूरक'' की सामान्यीकृत अवधारणा (जैसा कि नीचे वर्णित है) [[संख्या सिद्धांत]] में भी मूल्यवान है, जैसे मिडी के प्रमेय में होता है। | ||
दशमलव प्रतिनिधित्व में दी गई संख्या का ''नौ' पूरक'' प्रत्येक अंक को उस अंक को घटाकर नौ से प्रतिस्थापित करके बनाया जाता है। दशमलव संख्या ''y'' ( | दशमलव प्रतिनिधित्व में दी गई संख्या का ''नौ' पूरक'' प्रत्येक अंक को उस अंक को घटाकर नौ से प्रतिस्थापित करके बनाया जाता है। दशमलव संख्या ''y'' (सबट्रेंड) को दूसरी संख्या ''x'' (मीनूएंड) से घटाने के लिए दो विधियों का उपयोग किया जा सकता है: | ||
पहली विधि में ''x'' के नौ पूरक को ''y'' में जोड़ा जाता है। फिर वांछित परिणाम उत्पन्न करने के लिए प्राप्त परिणाम का नाइन पूरक बनाया जाता है। | पहली विधि में ''x'' के नौ पूरक को ''y'' में जोड़ा जाता है। फिर वांछित परिणाम उत्पन्न करने के लिए प्राप्त परिणाम का नाइन पूरक बनाया जाता है। | ||
दूसरी विधि में ''y'' के नौ पूरक को ''x'' में जोड़ा जाता है और योग में जोड़ा जाता है। फिर परिणाम का सबसे बायां अंक '1' हटा दिया जाता है। सबसे बाईं ओर के '1' को हटाना विशेष रूप से कैलकुलेटर या कंप्यूटर पर सुविधाजनक होता है जो अंकों की निश्चित संख्या का उपयोग करते हैं: इसके जाने के लिए कहीं नहीं है इसलिए यह गणना के | दूसरी विधि में ''y'' के नौ पूरक को ''x'' में जोड़ा जाता है और योग में जोड़ा जाता है। फिर परिणाम का सबसे बायां अंक '1' हटा दिया जाता है। सबसे बाईं ओर के '1' को हटाना विशेष रूप से कैलकुलेटर या कंप्यूटर पर सुविधाजनक होता है जो अंकों की निश्चित संख्या का उपयोग करते हैं: इसके जाने के लिए कहीं नहीं है इसलिए यह गणना के समय बस खो जाता है। नौ का पूरक और को ''दस का पूरक'' के रूप में जाना जाता है। | ||
पूरक की विधि को अन्य संख्या आधारों ([[मूलांक]]) तक बढ़ाया जा सकता है; विशेष रूप से, इसका उपयोग अधिकांश डिजिटल कंप्यूटरों पर घटाव करने, आधार 2 या [[बाइनरी संख्या]] में नकारात्मक संख्याओं का प्रतिनिधित्व करने और गणना में अंडरफ्लो और ओवरफ्लो का परीक्षण करने के लिए किया जाता है। | पूरक की विधि को अन्य संख्या आधारों ([[मूलांक]]) तक बढ़ाया जा सकता है; विशेष रूप से, इसका उपयोग अधिकांश डिजिटल कंप्यूटरों पर घटाव करने, आधार 2 या [[बाइनरी संख्या]] में नकारात्मक संख्याओं का प्रतिनिधित्व करने और गणना में अंडरफ्लो और ओवरफ्लो का परीक्षण करने के लिए किया जाता है।<ref>[http://cs.fit.edu/~wds/classes/adm/Lectures/TensComplement.pdf Florida Tech]</ref> | ||
<ref>[http://cs.fit.edu/~wds/classes/adm/Lectures/TensComplement.pdf Florida Tech]</ref> | |||
==संख्यात्मक पूरक== | ==संख्यात्मक पूरक == | ||
मूलांक का पूरक | मूलांक का पूरक <math>n</math> अंकों की संख्या <math>y</math> मूलांक में <math>b</math> परिभाषित किया जाता है <math>b^n - y</math>. व्यवहार में, मूलांक पूरक को कम मूलांक पूरक में 1 जोड़कर अधिक सरलता से प्राप्त किया जा सकता है, जो कि है <math>\left(b^n - 1\right) - y</math>. चूँकि मूलांक पूरक के रूप में इसकी गणना करना उतना ही कठिन लगता है, यह वास्तव में सरल है <math>\left(b^n - 1\right)</math> बस अंक है <math>b - 1</math> दोहराया गया <math>n</math> बार. यह है क्योंकि<math>b^n - 1 = (b - 1)\left(b^{n-1} + b^{n-2} + \cdots + b + 1\right) = (b - 1)b^{n-1} + \cdots + (b - 1)</math> (ज्यामितीय श्रृंखला भी देखें)। यह जानकर, प्रत्येक अंक को उसके सापेक्ष पूरक करके किसी संख्या का घटा हुआ मूलांक <math>b - 1</math>, अर्थात प्रत्येक अंक को घटाना <math>y</math> से <math>b - 1</math>. पूरक पाया जा सकता है | ||
घटाव <math>y</math> से <math>x</math> घटे हुए मूलांक पूरकों का उपयोग निम्नानुसार किया जा सकता है। जिसका घटा हुआ मूलांक पूरक जोड़ें <math>x</math> को <math>y</math> प्राप्त करने के लिए <math>b^n - 1 - x + y</math> या समकक्ष <math>b^n - 1 - (x - y)</math>, जो कि घटा हुआ मूलांक पूरक है <math>x-y</math>. आगे घटते मूलांक पूरक को लेते हुए <math>b^n - 1 - (x - y)</math> का वांछित <math>x - y</math> उत्तर प्राप्त होता है . | |||
वैकल्पिक रूप से मूलांक पूरक का उपयोग करते हुए, <math>x-y</math> का मूलांक पूरक जोड़कर प्राप्त किया जा सकता है <math>y</math> को <math>x</math> प्राप्त करने के लिए <math>x + b^n - y</math> या <math>x - y + b^n</math>. यह मानते हुए <math>y \leq x</math> , परिणाम बड़ा या बराबर होगा <math>b^n</math> और अग्रणी को गिराना <math>1</math> परिणाम से घटाना | वैकल्पिक रूप से मूलांक पूरक का उपयोग करते हुए, <math>x-y</math> का मूलांक पूरक जोड़कर प्राप्त किया जा सकता है <math>y</math> को <math>x</math> प्राप्त करने के लिए <math>x + b^n - y</math> या <math>x - y + b^n</math>. यह मानते हुए <math>y \leq x</math> , परिणाम बड़ा या बराबर होगा <math>b^n</math> और अग्रणी को गिराना <math>1</math> परिणाम से घटाना <math>b^n</math> समान है , परिणाम बना रहा है <math>x - y + b^n - b^n</math> या केवल <math>x - y</math>, वांछित परिणाम है. | ||
[[दशमलव]] संख्या प्रणाली में, मूलांक पूरक को दहाई का पूरक कहा जाता है और घटे हुए मूलांक को नौ का पूरक कहा जाता है। [[बाइनरी अंक प्रणाली]] में, मूलांक पूरक को दो का पूरक कहा जाता है और घटे हुए मूलांक को इकाई का पूरक कहा जाता है। अन्य आधारों पर पूरकों का नामकरण भी इसी प्रकार है। कुछ लोग, विशेष रूप से [[डोनाल्ड नुथ]], मूलांक पूरक और घटे हुए मूलांक पूरक के बीच अंतर करने के लिए एपोस्ट्रोफ के स्थान का उपयोग करने की सलाह देते हैं। इस उपयोग में, चार का पूरक आधार चार में संख्या के मूलांक पूरक को संदर्भित करता है जबकि चार का पूरक आधार 5 में संख्या का घटा हुआ मूलांक पूरक है। | [[दशमलव]] संख्या प्रणाली में, मूलांक पूरक को दहाई का पूरक कहा जाता है और घटे हुए मूलांक को नौ का पूरक कहा जाता है। [[बाइनरी अंक प्रणाली]] में, मूलांक पूरक को दो का पूरक कहा जाता है और घटे हुए मूलांक को इकाई का पूरक कहा जाता है। अन्य आधारों पर पूरकों का नामकरण भी इसी प्रकार है। कुछ लोग, विशेष रूप से [[डोनाल्ड नुथ]], मूलांक पूरक और घटे हुए मूलांक पूरक के बीच अंतर करने के लिए एपोस्ट्रोफ के स्थान का उपयोग करने की सलाह देते हैं। इस उपयोग में, चार का पूरक आधार चार में संख्या के मूलांक पूरक को संदर्भित करता है जबकि चार का पूरक आधार 5 में संख्या का घटा हुआ मूलांक पूरक है। चूँकि, जब मूलांक स्पष्ट होता है (लगभग सदैव) तो अंतर महत्वपूर्ण नहीं होता है , और एपोस्ट्रोफ प्लेसमेंट में सूक्ष्म अंतर सामान्य बात नहीं है। अधिकांश लेखक वन और नाइन के पूरक का उपयोग करते हैं, और कई स्टाइल मैनुअल एपॉस्ट्रॉफ़ी को छोड़ देते हैं, वन और नाइन के पूरक की अनुशंसा करते हैं। | ||
==दशमलव उदाहरण== | ==दशमलव उदाहरण == | ||
{| class="wikitable floatright" | {| class="wikitable floatright" | ||
! | ! अंक | ||
! | ! नौ | ||
पूरक | |||
|-align="center" | |-align="center" | ||
| 0 | | 0 | ||
Line 58: | Line 58: | ||
दशमलव अंक का नौ पूरक वह संख्या है जिसे 9 प्राप्त करने के लिए इसमें जोड़ा जाना चाहिए; 3 का नाइन का पूरक 6 है, 7 का नाइन का पूरक 2 है, इत्यादि, तालिका देखें। किसी बड़ी संख्या का नौ का पूरक बनाने के लिए, प्रत्येक अंक को उसके नौ के पूरक से बदल दिया जाता है। | दशमलव अंक का नौ पूरक वह संख्या है जिसे 9 प्राप्त करने के लिए इसमें जोड़ा जाना चाहिए; 3 का नाइन का पूरक 6 है, 7 का नाइन का पूरक 2 है, इत्यादि, तालिका देखें। किसी बड़ी संख्या का नौ का पूरक बनाने के लिए, प्रत्येक अंक को उसके नौ के पूरक से बदल दिया जाता है। | ||
निम्नलिखित घटाव समस्या पर विचार करें: | निम्नलिखित घटाव समस्या पर विचार करें:<syntaxhighlight lang="abl"> | ||
873 [x, the minuend] | |||
- 218 [y, the subtrahend] | |||
</syntaxhighlight> | |||
=== पहली विधि === | === पहली विधि === | ||
मीनूएंड, 873 के नाइन के पूरक की गणना करें। इसे उपट्रेंड 218 में जोड़ें, फिर परिणाम के नाइन के पूरक की गणना करें। | मीनूएंड, 873 के नाइन के पूरक की गणना करें। इसे उपट्रेंड 218 में जोड़ें, फिर परिणाम के नाइन के पूरक की गणना करें।<syntaxhighlight> | ||
126 [nines' complement of x = 999 - x] | |||
+ 218 [y, the subtrahend] | |||
————— | |||
344 [999 - x + y] | |||
</syntaxhighlight>अब परिणाम के नौ पूरक की गणना करें<syntaxhighlight> | |||
344 [result] | |||
अब परिणाम के नौ पूरक की गणना करें | 655 [nines' complement of 344 = 999 - (999 - x + y) = x - y, the correct answer] | ||
</syntaxhighlight> | |||
===दूसरी विधि === | ===दूसरी विधि === | ||
218 के नौ के पूरक की गणना करें, जो 781 है। क्योंकि 218 तीन अंक लंबा है, यह 999 में से 218 घटाने के समान है। | 218 के नौ के पूरक की गणना करें, जो 781 है। क्योंकि 218 तीन अंक लंबा है, यह 999 में से 218 घटाने के समान है। | ||
अगला, का योग <math>x</math> और नौ का पूरक <math>y</math> लिया जाता है: | अगला, का योग <math>x</math> और नौ का पूरक <math>y</math> लिया जाता है:<syntaxhighlight> | ||
873 [x] | |||
+ 781 [nines' complement of y = 999 - y] | |||
————— | |||
1654 [999 + x - y] | |||
</syntaxhighlight>फिर अग्रणी 1 अंक हटा दिया जाता है, जिससे 654 मिलता है। | |||
फिर अग्रणी 1 अंक हटा दिया जाता है, जिससे 654 मिलता है। | |||
1654 | 1654 | ||
-1000 [-(999 + 1)] | -1000 [-(999 + 1)] | ||
Line 100: | Line 95: | ||
655 [x - y] | 655 [x - y] | ||
1 जोड़ने पर 655 मिलता है, जो हमारी मूल घटाव समस्या का सही उत्तर है। 1 जोड़ने का अंतिम चरण छोड़ा जा सकता है यदि इसके | 1 जोड़ने पर 655 मिलता है, जो हमारी मूल घटाव समस्या का सही उत्तर है। 1 जोड़ने का अंतिम चरण छोड़ा जा सकता है यदि इसके अतिरिक्त पहले चरण में y के दहाई के पूरक का उपयोग किया गया हो। | ||
=== संख्याओं का परिमाण === | === संख्याओं का परिमाण === | ||
निम्नलिखित उदाहरण में घटाव के परिणाम में इससे कम अंक हैं <math>x</math>: 1234 10 [x, मीनुएंड] - 123401 | निम्नलिखित उदाहरण में घटाव के परिणाम में इससे कम अंक हैं <math>x</math>: 1234 10 [x, मीनुएंड] - 123401 y, वे घटाते हैं पहली विधि का उपयोग करके नौ के पूरक का योग <math>x</math> और <math>y</math> है<syntaxhighlight> | ||
पहली विधि का उपयोग करके नौ के पूरक का योग <math>x</math> और <math>y</math> है | 876589 [nines' complement of x] | ||
+ 123401 [y] | |||
———————— | |||
999990 | |||
</syntaxhighlight>999990 का नाइन पूरक 000009 है। अग्रणी शून्य को हटाने से 9 वांछित परिणाम मिलता है। | |||
999990 का नाइन पूरक 000009 है। अग्रणी शून्य को हटाने से 9 वांछित परिणाम मिलता है। | |||
यदि उपप्रकार, <math>y</math>, मीनूएंड से कम अंक हैं, <math>x</math>, दूसरी विधि में अग्रणी शून्य अवश्य जोड़ा जाना चाहिए। पूरक लेने पर ये शून्य अग्रणी नौ बन जाते हैं। उदाहरण के लिए:<syntaxhighlight> | |||
48032 [x] | |||
+1 | - 391 [y] | ||
</syntaxhighlight>पुनः लिखा जा सकता है<syntaxhighlight> | |||
48032 [x] | |||
- 00391 [y with leading zeros] | |||
</syntaxhighlight>00391 को इसके नौ पूरक के साथ प्रतिस्थापित करने और 1 जोड़ने से योग उत्पन्न होता है:<syntaxhighlight> | |||
48032 [x] | |||
+ 99608 [nines' complement of y] | |||
+ 1 | |||
——————— | |||
147641 | |||
</syntaxhighlight>अग्रणी 1 को हटाने पर सही उत्तर मिलता है: 47641। | |||
==बाइनरी विधि == | |||
==बाइनरी विधि== | |||
{| class="wikitable floatright" | {| class="wikitable floatright" | ||
! | ! बाइनरी | ||
! | अंक | ||
|-align="center" | ! वन्स' | ||
पूरक | |||
|- align="center" | |||
| 0 | | 0 | ||
| 1 | | 1 | ||
|-align="center" | |- align="center" | ||
| 1 | | 1 | ||
| 0 | | 0 | ||
|} | |} | ||
पूरक की विधि बाइनरी (मूलांक 2) में विशेष रूप से उपयोगी है क्योंकि प्रत्येक बिट को उल्टा करके ('0' को '1' में बदलकर और इसके विपरीत) द्वारा पूरक बहुत | पूरक की विधि बाइनरी (मूलांक 2) में विशेष रूप से उपयोगी है क्योंकि प्रत्येक बिट को उल्टा करके ('0' को '1' में बदलकर और इसके विपरीत) द्वारा पूरक बहुत सरलता से प्राप्त किया जा सकता है। कम से कम महत्वपूर्ण बिट में कैरी का अनुकरण करके दोनों का पूरक प्राप्त करने के लिए 1 जोड़ा जा सकता है। उदाहरण के लिए:<syntaxhighlight> | ||
0110 0100 [x, equals decimal 100] | |||
- 0001 0110 [y, equals decimal 22] | |||
</syntaxhighlight>योग बन जाता है:<syntaxhighlight> | |||
0110 0100 [x] | |||
योग बन जाता है: | + 1110 1001 [ones' complement of y = 1111 1111 - y] | ||
+ 1 [to get the two's complement = 1 0000 0000 - y] | |||
——————————— | |||
10100 1110 [x + 1 0000 0000 - y] | |||
</syntaxhighlight> | |||
आरंभिक 1 को हटाने पर उत्तर मिलता है: 0100 1110 (दशमलव 78 के बराबर) | आरंभिक 1 को हटाने पर उत्तर मिलता है: 0100 1110 (दशमलव 78 के बराबर) | ||
==ऋणात्मक संख्या निरूपण== | ==ऋणात्मक संख्या निरूपण== | ||
{{main article| | {{main article|हस्ताक्षरित संख्या प्रतिनिधित्व}} | ||
पूरक की विधि | पूरक की विधि सामान्यतः मानती है कि ऑपरेंड सकारात्मक हैं और y ≤ x, तार्किक बाधाएं दी गई हैं कि सही विधि से पूर्णांकों को जोड़ना और घटाना सामान्यतः संकेतों की तुलना करके, दोनों को जोड़कर या बड़े से छोटे को घटाकर किया जाता है, और परिणाम सही होता है संकेत। | ||
आइए देखें कि यदि x < y हो तो क्या होता है। उस स्थिति में, जोड़ने के बाद काटने के लिए 1 अंक नहीं होगा <math>x-y+b^n</math> से कम होगा <math>b^n</math>. उदाहरण के लिए, (दशमलव में): | आइए देखें कि यदि x < y हो तो क्या होता है। उस स्थिति में, जोड़ने के बाद काटने के लिए 1 अंक नहीं होगा <math>x-y+b^n</math> से कम होगा <math>b^n</math>. उदाहरण के लिए, (दशमलव में): | ||
185 [x] | 185 [x] | ||
- 329 [ | - 329 [y] | ||
y को पूरक करने और जोड़ने पर मिलता है: | y को पूरक करने और जोड़ने पर मिलता है: | ||
185 [x] | 185 [x] | ||
+ 670 [y | + 670 [nines' complement of y] | ||
+1 | +1 | ||
————— | ————— | ||
856 | 856 | ||
इस बिंदु पर, घटाकर गणना पूरी करने का कोई | इस बिंदु पर, घटाकर गणना पूरी करने का कोई सरल विधि नहीं है <math>b^n</math> (इस स्थिति में 1000); कोई भी अग्रणी 1 को अनदेखा नहीं कर सकता है। अपेक्षित उत्तर -144 है, जो उतना दूर नहीं है जितना लगता है; 856, 144 का दहाई का पूरक है। इस कथन को कई विधियों से संबोधित किया जा सकता है: | ||
* | * कथन पर ध्यान न दें. यह उचित है यदि कोई व्यक्ति गणना उपकरण चला रहा है जो नकारात्मक संख्याओं का समर्थन नहीं करता है क्योंकि गणना से पहले दो ऑपरेंड की तुलना करना ताकि उन्हें उचित क्रम में अंकित किया जा सके, और यह सत्यापित करना कि परिणाम उचित है, मनुष्यों के लिए ऐसा करना सरल है . | ||
* 1000 में से 856 घटाने के लिए उसी विधि का उपयोग करें, और फिर परिणाम में नकारात्मक चिह्न | * 1000 में से 856 घटाने के लिए उसी विधि का उपयोग करें, और फिर परिणाम में नकारात्मक चिह्न जोड़ें है। | ||
* ऋणात्मक संख्याओं को उनके धनात्मक समकक्षों के मूलांक पूरक के रूप में निरूपित करें। से कम संख्या <math>b^n/2</math> सकारात्मक माने जाते हैं; बाकी को नकारात्मक माना जाता है (और उनका परिमाण मूलांक पूरक लेकर प्राप्त किया जा सकता है)। यह सम मूलांकों के लिए सबसे अच्छा काम करता है क्योंकि चिह्न का निर्धारण पहले अंक को देखकर किया जा सकता है। उदाहरण के लिए, दस के पूरक अंकन में संख्याएँ सकारात्मक हैं यदि पहला अंक 0, 1, 2, 3, या 4 है, और यदि 5, 6, 7, 8, या 9 है तो नकारात्मक हैं। और यह पहले से ही बाइनरी में बहुत अच्छी तरह से काम करता है बिट को साइन बिट माना जा सकता है: यदि साइन बिट 0 है तो संख्या सकारात्मक है और यदि 1 है तो नकारात्मक है। वास्तव में, हस्ताक्षरित संख्याओं को दर्शाने के लिए अधिकांश आधुनिक कंप्यूटरों में दो के पूरक का उपयोग किया जाता है। | * ऋणात्मक संख्याओं को उनके धनात्मक समकक्षों के मूलांक पूरक के रूप में निरूपित करें। से कम संख्या <math>b^n/2</math> सकारात्मक माने जाते हैं; बाकी को नकारात्मक माना जाता है (और उनका परिमाण मूलांक पूरक लेकर प्राप्त किया जा सकता है)। यह सम मूलांकों के लिए सबसे अच्छा काम करता है क्योंकि चिह्न का निर्धारण पहले अंक को देखकर किया जा सकता है। उदाहरण के लिए, दस के पूरक अंकन में संख्याएँ सकारात्मक हैं यदि पहला अंक 0, 1, 2, 3, या 4 है, और यदि 5, 6, 7, 8, या 9 है तो नकारात्मक हैं। और यह पहले से ही बाइनरी में बहुत अच्छी तरह से काम करता है बिट को साइन बिट माना जा सकता है: यदि साइन बिट 0 है तो संख्या सकारात्मक है और यदि 1 है तो नकारात्मक है। वास्तव में, हस्ताक्षरित संख्याओं को दर्शाने के लिए अधिकांश आधुनिक कंप्यूटरों में दो के पूरक का उपयोग किया जाता है। | ||
* यदि सबसे महत्वपूर्ण अंक (एक संकेत है कि x, y से कम था) का कोई उपयोग नहीं होने पर परिणाम को पूरक करें। ऑपरेंड की तुलना और अदला-बदली करने की तुलना में इसे [[डिजिटल सर्किट]] के साथ | * यदि सबसे महत्वपूर्ण अंक (एक संकेत है कि x, y से कम था) का कोई उपयोग नहीं होने पर परिणाम को पूरक करें। ऑपरेंड की तुलना और अदला-बदली करने की तुलना में इसे [[डिजिटल सर्किट]] के साथ प्रयुक्त करना सरल है। किन्तु चूंकि मूलांक पूरक लेने के लिए 1 जोड़ने की आवश्यकता होती है, इसलिए इसे सीधे करना कठिन है। इस जोड़ से बचने के लिए तरकीब का उपयोग किया जा सकता है: घटाते समय कैरी आउट को सदैव सबसे कम महत्वपूर्ण अंक में सेट करने के अतिरिक्त, सबसे महत्वपूर्ण अंक के कैरी आउट को कम से कम महत्वपूर्ण अंक में कैरी इनपुट के रूप में उपयोग किया जाता है (एक ऑपरेशन जिसे कहा जाता है) । इसलिए यदि y ≤ x है, तो सबसे महत्वपूर्ण अंक जिसे सामान्यतः नजरअंदाज कर दिया जाता है, जिसको जोड़ दिया जाता है, जिससे सही परिणाम प्राप्त होता है। और यदि नहीं, तो 1 नहीं जोड़ा जाता है और परिणाम उत्तर के मूलांक पूरक से कम होता है, या घटा हुआ मूलांक पूरक होता है, जिसे प्राप्त करने के लिए जोड़ की आवश्यकता नहीं होती है। इस पद्धति का उपयोग उन कंप्यूटरों द्वारा किया जाता है जो हस्ताक्षरित संख्याओं को दर्शाने के लिए संकेत-और-परिमाण का उपयोग करते हैं। | ||
==व्यावहारिक उपयोग== | ==व्यावहारिक उपयोग== | ||
[[File:Comptometer1920Model.jpg|thumb|1920 के दशक का कॉम्पटोमीटर, जिसमें प्रत्येक कुंजी पर नौ पूरक अंकित हैं]]कई यांत्रिक कैलकुलेटरों में गियर को पीछे की ओर चलाने के विकल्प के रूप में पूरक की विधि का उपयोग किया गया था। उदाहरण के लिए: | [[File:Comptometer1920Model.jpg|thumb|1920 के दशक का कॉम्पटोमीटर, जिसमें प्रत्येक कुंजी पर नौ पूरक अंकित हैं]]कई यांत्रिक कैलकुलेटरों में गियर को पीछे की ओर चलाने के विकल्प के रूप में पूरक की विधि का उपयोग किया गया था। उदाहरण के लिए: | ||
* पास्कल के कैलकुलेटर में परिणाम अंकों के दो सेट थे, काला सेट जो सामान्य परिणाम प्रदर्शित करता था और लाल सेट जो नाइन के पूरक को प्रदर्शित करता था। इनमें से सेट को ढकने और दूसरे को | * पास्कल के कैलकुलेटर में परिणाम अंकों के दो सेट थे, काला सेट जो सामान्य परिणाम प्रदर्शित करता था और लाल सेट जो नाइन के पूरक को प्रदर्शित करता था। इनमें से सेट को ढकने और दूसरे को प्रदर्शित करने के लिए क्षैतिज स्लैट का उपयोग किया गया था। घटाने के लिए, लाल अंकों को प्रदर्शित किया गया और 0 पर सेट किया गया है। फिर मीनूएंड के नौ के पूरक को अंकित किया गया है। कुछ मशीनों पर इसे पूरक के आंतरिक पहियों का उपयोग करके मिनट में डायल करके किया जा सकता है (अर्थात मिनट के नाइन के पूरक को मानसिक रूप से निर्धारित किए बिना)। पूरक विंडो (लाल सेट) में उस डेटा को प्रदर्शित करने में, ऑपरेटर मीनूएंड के नाइन के पूरक के नाइन के पूरक को देख सकता है, जो कि मीनूएंड है। फिर काले अंकों को प्रदर्शित करने के लिए स्लैट को स्थानांतरित किया गया (जो अब मीनूएंड के नाइन के पूरक को प्रदर्शित करता है) और इसे डायल करके सबट्रेंड को जोड़ा गया था। अंत में, ऑपरेटर को सही उत्तर पढ़ने के लिए स्लैट को फिर से स्थानांतरित करना पड़ा था। | ||
* [[ कंप्टमीटर ]] में प्रत्येक कुंजी पर सामान्य अंकों के साथ-साथ नौ के पूरक अंक छोटे प्रकार में मुद्रित होते थे। घटाने के लिए, ऑपरेटर से मानसिक रूप से सबट्रेंड से 1 घटाने और छोटे अंकों का उपयोग करके परिणाम | * [[ कंप्टमीटर ]] में प्रत्येक कुंजी पर सामान्य अंकों के साथ-साथ नौ के पूरक अंक छोटे प्रकार में मुद्रित होते थे। घटाने के लिए, ऑपरेटर से मानसिक रूप से सबट्रेंड से 1 घटाने और छोटे अंकों का उपयोग करके परिणाम अंकित करने की अपेक्षा की गई थी। चूंकि पूरक करने से पहले 1 घटाना बाद में 1 जोड़ने के बराबर है, इसलिए ऑपरेटर प्रभावी रूप से सबट्रेंड के दस के पूरक को जोड़ देगा। ऑपरेटर को उत्तर के सबसे बाएं अंक के अनुरूप घटाव कटऑफ टैब को भी दबाकर रखना होगा। इस टैब ने कैरी को इसके आगे फैलने से रोका, परिणाम से प्रारंभिक 1 को हटाने की कॉम्पटोमीटर की विधि है।<ref>[http://ed-thelen.org/comp-hist/Comptometer-instructions.html Easy Instructions for Operation the Controlled Key Comptometer], Comptometer Division, Felt and Tarrant Mfg. Co., Chicago, 1917, p. 12</ref> | ||
* [[कंप्यूटर साफ़ करें]] ने घटाव के लिए पूरक की विधि का उपयोग किया, और इसे उपयोगकर्ता से छिपाने में कामयाब | * [[कंप्यूटर साफ़ करें|कंप्यूटर]] ने घटाव के लिए पूरक की विधि का उपयोग किया था, और इसे उपयोगकर्ता से छिपाने में कामयाब रहा था। डिवाइस के किनारे अंक इनपुट स्लाइड का उपयोग करके नंबर अंकित किए गए थे। प्रत्येक स्लाइड पर संख्या को गियरिंग तंत्र द्वारा परिणाम काउंटर में जोड़ा गया था, जो घूर्णन सोपानक ड्रम (a.k.a. स्टेप ड्रम) पर कैम लगाता था। उपकरण के शीर्ष पर क्रैंक का उपयोग करके ड्रम को घुमाया जाता था। क्रैंक चालू होने पर प्रत्येक अंक द्वारा सामना किए गए कैम की संख्या उस अंक के मूल्य से निर्धारित की जाती थी। उदाहरण के लिए, यदि स्लाइड को उसकी 6वीं स्थिति पर सेट किया जाता है, जिससे उस स्थिति के अनुरूप ड्रम के चारों ओर 6 कैमों की पंक्ति सामने आएगी। घटाने के लिए, ड्रम को घुमाने से पहले थोड़ा सा स्थानांतरित किया गया, जिससे कैम की अलग पंक्ति स्थिति में आ गई थी। इस वैकल्पिक पंक्ति में अंकों का नौ पूरक सम्मिलित था। इस प्रकार, 6 कैमों की पंक्ति जो जोड़ने की स्थिति में थी, अब 3 कैमों वाली पंक्ति थी। स्थानांतरित ड्रम में अतिरिक्त कैम भी सम्मिलित था जिसने परिणाम में 1 जोड़ा (जैसा कि पूरक की विधि के लिए आवश्यक था)। सदैव उपस्थित दहाई का पूरक अतिप्रवाह 1, जो परिणाम रजिस्टर के सबसे महत्वपूर्ण अंक से परे किया गया था, वास्तव में, खारिज कर दिया गया था। | ||
===कंप्यूटर में=== | ===कंप्यूटर में=== | ||
हस्ताक्षरित संख्याओं के लिए उपयोग किए जाने वाले प्रतिनिधित्व की परवाह किए बिना, डिजिटल कंप्यूटरों में पूरक की विधि का उपयोग सर्वव्यापी है। | हस्ताक्षरित संख्याओं के लिए उपयोग किए जाने वाले प्रतिनिधित्व की परवाह किए बिना, डिजिटल कंप्यूटरों में पूरक की विधि का उपयोग सर्वव्यापी है। चूँकि, आवश्यक सर्किटरी प्रतिनिधित्व पर निर्भर करती है: | ||
* यदि दो के पूरक प्रतिनिधित्व का उपयोग किया जाता है, | * यदि दो के पूरक प्रतिनिधित्व का उपयोग किया जाता है, जिससे घटाव के लिए केवल सबट्रेंड के बिट्स को उल्टा करना और कैरी को सबसे दाहिने बिट में सेट करना आवश्यक है। | ||
* किसी के पूरक प्रतिनिधित्व का उपयोग करने के लिए सबट्रेंड के बिट्स को उलटने और सबसे महत्वपूर्ण बिट के कैरी आउट को कम से कम महत्वपूर्ण बिट (एंड-अराउंड कैरी) के कैरी आउट से जोड़ने की आवश्यकता होती है। | * किसी के पूरक प्रतिनिधित्व का उपयोग करने के लिए सबट्रेंड के बिट्स को उलटने और सबसे महत्वपूर्ण बिट के कैरी आउट को कम से कम महत्वपूर्ण बिट (एंड-अराउंड कैरी) के कैरी आउट से जोड़ने की आवश्यकता होती है। | ||
* साइन-परिमाण प्रतिनिधित्व का उपयोग करने के लिए केवल सबट्रेंड के साइन बिट को पूरक करने और जोड़ने की आवश्यकता होती है, | * साइन-परिमाण प्रतिनिधित्व का उपयोग करने के लिए केवल सबट्रेंड के साइन बिट को पूरक करने और जोड़ने की आवश्यकता होती है, किन्तु जोड़/घटाव तर्क को साइन बिट्स की तुलना करने की आवश्यकता होती है, यदि वे अलग-अलग हैं तो इनपुट में से को पूरक करें, एंड-अराउंड कैरी प्रयुक्त करें, और पूरक करें परिणाम यदि सबसे महत्वपूर्ण बिट से कोई कैरी नहीं था। | ||
===मैन्युअल उपयोग=== | ===मैन्युअल उपयोग=== | ||
जब लेखांकन पुस्तकें हाथ से लिखी जाती थीं तो त्रुटियों को ठीक करने के लिए पूरक की विधि का उपयोग किया जाता था। संख्याओं के कॉलम से प्रविष्टि को हटाने के लिए, अकाउंटेंट घटाने के लिए संख्या के दस के पूरक के साथ नई प्रविष्टि जोड़ सकता है। इसकी विशेष स्थिति को दर्शाने के लिए इस प्रविष्टि के अंकों के ऊपर बार जोड़ा गया था। फिर सही परिणाम प्राप्त करने के लिए आंकड़ों के पूरे कॉलम को जोड़ना संभव हो गया। | जब लेखांकन पुस्तकें हाथ से लिखी जाती थीं तो त्रुटियों को ठीक करने के लिए पूरक की विधि का उपयोग किया जाता था। संख्याओं के कॉलम से प्रविष्टि को हटाने के लिए, अकाउंटेंट घटाने के लिए संख्या के दस के पूरक के साथ नई प्रविष्टि जोड़ सकता है। इसकी विशेष स्थिति को दर्शाने के लिए इस प्रविष्टि के अंकों के ऊपर बार जोड़ा गया था। फिर सही परिणाम प्राप्त करने के लिए आंकड़ों के पूरे कॉलम को जोड़ना संभव हो गया। | ||
मुद्रा के आधार की पूर्णांक शक्ति तक बढ़ाए गए 1 के एकल मूल्यवर्ग में मुद्रा से खरीदारी के लिए परिवर्तन करने वाले कैशियर के लिए राशि को | मुद्रा के आधार की पूर्णांक शक्ति तक बढ़ाए गए 1 के एकल मूल्यवर्ग में मुद्रा से खरीदारी के लिए परिवर्तन करने वाले कैशियर के लिए राशि को प्रयुक्त करना सरल है। दशमलव मुद्राओं के लिए जो 10, 100, 1,000, आदि होंगी, उदा. $10.00 का बिल था | ||
==ग्रेड | ==ग्रेड स्कूल शिक्षा में== | ||
ग्रेड स्कूलों में, छात्रों को कभी-कभी [[मानसिक अंकगणित]] में उपयोगी शॉर्टकट के रूप में पूरक की विधि सिखाई जाती है।<ref>{{cite book | title = प्राथमिक विद्यालय के शिक्षकों के लिए अंकगणित और ज्यामिति के सिद्धांत| author = Carl Barnett Allendoerfer | publisher = Macmillan | year = 1971 }}</ref> घटाव सबट्रेंड के दहाई के पूरक को जोड़कर किया जाता है, जो नौ का पूरक प्लस 1 है। इस जोड़ के परिणाम का उपयोग तब किया जाता है जब यह स्पष्ट हो कि अंतर सकारात्मक होगा, अन्यथा जोड़ के परिणाम के दहाई के पूरक का उपयोग किया जाता है। इसे नकारात्मक के रूप में चिह्नित किया | ग्रेड स्कूलों में, छात्रों को कभी-कभी [[मानसिक अंकगणित]] में उपयोगी शॉर्टकट के रूप में पूरक की विधि सिखाई जाती है।<ref>{{cite book | title = प्राथमिक विद्यालय के शिक्षकों के लिए अंकगणित और ज्यामिति के सिद्धांत| author = Carl Barnett Allendoerfer | publisher = Macmillan | year = 1971 }}</ref> घटाव सबट्रेंड के दहाई के पूरक को जोड़कर किया जाता है, जो नौ का पूरक प्लस 1 है। इस जोड़ के परिणाम का उपयोग तब किया जाता है जब यह स्पष्ट हो कि अंतर सकारात्मक होगा, अन्यथा जोड़ के परिणाम के दहाई के पूरक का उपयोग किया जाता है। इसे नकारात्मक के रूप में चिह्नित किया गया था। यही तकनीक जोड़ने वाली मशीन पर घटाने के लिए भी काम करती है। | ||
==यह भी देखें== | ==यह भी देखें== | ||
*दो का पूरक - बाइनरी कंप्यूटर के लिए विशेष | *दो का पूरक - बाइनरी कंप्यूटर के लिए विशेष स्थिति | ||
==संदर्भ== | ==संदर्भ== |
Revision as of 17:14, 5 July 2023
गणित और कम्प्यूटिंग में, पूरक की विधि सकारात्मक और नकारात्मक पूर्णांक की सममित श्रेणी को इस तरह से एन्कोड करने की तकनीक है कि वे पूरी श्रृंखला में जोड़ने के लिए ही कलन विधि (हार्डवेयर) का उपयोग कर सकते हैं। स्थितीय संकेतन की दी गई संख्या के लिए संख्याओं के संभावित निरूपण का आधा भाग सकारात्मक संख्याओं को कूटबद्ध करता है, अन्य आधा उनके संबंधित योगात्मक व्युत्क्रमों का प्रतिनिधित्व करता है। परस्पर योगात्मक व्युत्क्रम संख्याओं के युग्मों को पूरक कहा जाता है। इस प्रकार किसी भी संख्या का घटाव उसके पूरक को जोड़कर क्रियान्वित किया जाता है। किसी भी संख्या के चिह्न को बदलना उसके पूरक को उत्पन्न करके एन्कोड किया जाता है, जिसे बहुत ही सरल और कुशल एल्गोरिदम द्वारा किया जा सकता है। यह विधि सामान्यतः यांत्रिक कैलकुलेटर में उपयोग की जाती थी और अभी भी आधुनिक कंप्यूटर में उपयोग की जाती है। रेडिक्स पूरक की सामान्यीकृत अवधारणा (जैसा कि नीचे वर्णित है) संख्या सिद्धांत में भी मूल्यवान है, जैसे मिडी के प्रमेय में होता है।
दशमलव प्रतिनिधित्व में दी गई संख्या का नौ' पूरक प्रत्येक अंक को उस अंक को घटाकर नौ से प्रतिस्थापित करके बनाया जाता है। दशमलव संख्या y (सबट्रेंड) को दूसरी संख्या x (मीनूएंड) से घटाने के लिए दो विधियों का उपयोग किया जा सकता है:
पहली विधि में x के नौ पूरक को y में जोड़ा जाता है। फिर वांछित परिणाम उत्पन्न करने के लिए प्राप्त परिणाम का नाइन पूरक बनाया जाता है।
दूसरी विधि में y के नौ पूरक को x में जोड़ा जाता है और योग में जोड़ा जाता है। फिर परिणाम का सबसे बायां अंक '1' हटा दिया जाता है। सबसे बाईं ओर के '1' को हटाना विशेष रूप से कैलकुलेटर या कंप्यूटर पर सुविधाजनक होता है जो अंकों की निश्चित संख्या का उपयोग करते हैं: इसके जाने के लिए कहीं नहीं है इसलिए यह गणना के समय बस खो जाता है। नौ का पूरक और को दस का पूरक के रूप में जाना जाता है।
पूरक की विधि को अन्य संख्या आधारों (मूलांक) तक बढ़ाया जा सकता है; विशेष रूप से, इसका उपयोग अधिकांश डिजिटल कंप्यूटरों पर घटाव करने, आधार 2 या बाइनरी संख्या में नकारात्मक संख्याओं का प्रतिनिधित्व करने और गणना में अंडरफ्लो और ओवरफ्लो का परीक्षण करने के लिए किया जाता है।[1]
संख्यात्मक पूरक
मूलांक का पूरक अंकों की संख्या मूलांक में परिभाषित किया जाता है . व्यवहार में, मूलांक पूरक को कम मूलांक पूरक में 1 जोड़कर अधिक सरलता से प्राप्त किया जा सकता है, जो कि है . चूँकि मूलांक पूरक के रूप में इसकी गणना करना उतना ही कठिन लगता है, यह वास्तव में सरल है बस अंक है दोहराया गया बार. यह है क्योंकि (ज्यामितीय श्रृंखला भी देखें)। यह जानकर, प्रत्येक अंक को उसके सापेक्ष पूरक करके किसी संख्या का घटा हुआ मूलांक , अर्थात प्रत्येक अंक को घटाना से . पूरक पाया जा सकता है
घटाव से घटे हुए मूलांक पूरकों का उपयोग निम्नानुसार किया जा सकता है। जिसका घटा हुआ मूलांक पूरक जोड़ें को प्राप्त करने के लिए या समकक्ष , जो कि घटा हुआ मूलांक पूरक है . आगे घटते मूलांक पूरक को लेते हुए का वांछित उत्तर प्राप्त होता है .
वैकल्पिक रूप से मूलांक पूरक का उपयोग करते हुए, का मूलांक पूरक जोड़कर प्राप्त किया जा सकता है को प्राप्त करने के लिए या . यह मानते हुए , परिणाम बड़ा या बराबर होगा और अग्रणी को गिराना परिणाम से घटाना समान है , परिणाम बना रहा है या केवल , वांछित परिणाम है.
दशमलव संख्या प्रणाली में, मूलांक पूरक को दहाई का पूरक कहा जाता है और घटे हुए मूलांक को नौ का पूरक कहा जाता है। बाइनरी अंक प्रणाली में, मूलांक पूरक को दो का पूरक कहा जाता है और घटे हुए मूलांक को इकाई का पूरक कहा जाता है। अन्य आधारों पर पूरकों का नामकरण भी इसी प्रकार है। कुछ लोग, विशेष रूप से डोनाल्ड नुथ, मूलांक पूरक और घटे हुए मूलांक पूरक के बीच अंतर करने के लिए एपोस्ट्रोफ के स्थान का उपयोग करने की सलाह देते हैं। इस उपयोग में, चार का पूरक आधार चार में संख्या के मूलांक पूरक को संदर्भित करता है जबकि चार का पूरक आधार 5 में संख्या का घटा हुआ मूलांक पूरक है। चूँकि, जब मूलांक स्पष्ट होता है (लगभग सदैव) तो अंतर महत्वपूर्ण नहीं होता है , और एपोस्ट्रोफ प्लेसमेंट में सूक्ष्म अंतर सामान्य बात नहीं है। अधिकांश लेखक वन और नाइन के पूरक का उपयोग करते हैं, और कई स्टाइल मैनुअल एपॉस्ट्रॉफ़ी को छोड़ देते हैं, वन और नाइन के पूरक की अनुशंसा करते हैं।
दशमलव उदाहरण
अंक | नौ
पूरक |
---|---|
0 | 9 |
1 | 8 |
2 | 7 |
3 | 6 |
4 | 5 |
5 | 4 |
6 | 3 |
7 | 2 |
8 | 1 |
9 | 0 |
दशमलव अंक का नौ पूरक वह संख्या है जिसे 9 प्राप्त करने के लिए इसमें जोड़ा जाना चाहिए; 3 का नाइन का पूरक 6 है, 7 का नाइन का पूरक 2 है, इत्यादि, तालिका देखें। किसी बड़ी संख्या का नौ का पूरक बनाने के लिए, प्रत्येक अंक को उसके नौ के पूरक से बदल दिया जाता है।
निम्नलिखित घटाव समस्या पर विचार करें:
873 [x, the minuend]
- 218 [y, the subtrahend]
पहली विधि
मीनूएंड, 873 के नाइन के पूरक की गणना करें। इसे उपट्रेंड 218 में जोड़ें, फिर परिणाम के नाइन के पूरक की गणना करें।
126 [nines' complement of x = 999 - x]
+ 218 [y, the subtrahend]
—————
344 [999 - x + y]
अब परिणाम के नौ पूरक की गणना करें
344 [result]
655 [nines' complement of 344 = 999 - (999 - x + y) = x - y, the correct answer]
दूसरी विधि
218 के नौ के पूरक की गणना करें, जो 781 है। क्योंकि 218 तीन अंक लंबा है, यह 999 में से 218 घटाने के समान है।
अगला, का योग और नौ का पूरक लिया जाता है:
873 [x]
+ 781 [nines' complement of y = 999 - y]
—————
1654 [999 + x - y]
फिर अग्रणी 1 अंक हटा दिया जाता है, जिससे 654 मिलता है।
1654 -1000 [-(999 + 1)] ————— 654 [-(999 + 1) + 999 + x - y]
ये अभी तक सही नहीं है. पहले चरण में, समीकरण में 999 जोड़ा गया। फिर जब अग्रणी 1 हटा दिया गया तो 1000 घटा दिया गया। तो, प्राप्त उत्तर (654) सही उत्तर से कम है . इसे ठीक करने के लिए, उत्तर में 1 जोड़ा गया है:
654 +1 ————— 655 [x - y]
1 जोड़ने पर 655 मिलता है, जो हमारी मूल घटाव समस्या का सही उत्तर है। 1 जोड़ने का अंतिम चरण छोड़ा जा सकता है यदि इसके अतिरिक्त पहले चरण में y के दहाई के पूरक का उपयोग किया गया हो।
संख्याओं का परिमाण
निम्नलिखित उदाहरण में घटाव के परिणाम में इससे कम अंक हैं : 1234 10 [x, मीनुएंड] - 123401 y, वे घटाते हैं पहली विधि का उपयोग करके नौ के पूरक का योग और है
876589 [nines' complement of x]
+ 123401 [y]
————————
999990
999990 का नाइन पूरक 000009 है। अग्रणी शून्य को हटाने से 9 वांछित परिणाम मिलता है। यदि उपप्रकार, , मीनूएंड से कम अंक हैं, , दूसरी विधि में अग्रणी शून्य अवश्य जोड़ा जाना चाहिए। पूरक लेने पर ये शून्य अग्रणी नौ बन जाते हैं। उदाहरण के लिए:
48032 [x]
- 391 [y]
पुनः लिखा जा सकता है
48032 [x]
- 00391 [y with leading zeros]
00391 को इसके नौ पूरक के साथ प्रतिस्थापित करने और 1 जोड़ने से योग उत्पन्न होता है:
48032 [x]
+ 99608 [nines' complement of y]
+ 1
———————
147641
अग्रणी 1 को हटाने पर सही उत्तर मिलता है: 47641।
बाइनरी विधि
बाइनरी
अंक |
वन्स'
पूरक |
---|---|
0 | 1 |
1 | 0 |
पूरक की विधि बाइनरी (मूलांक 2) में विशेष रूप से उपयोगी है क्योंकि प्रत्येक बिट को उल्टा करके ('0' को '1' में बदलकर और इसके विपरीत) द्वारा पूरक बहुत सरलता से प्राप्त किया जा सकता है। कम से कम महत्वपूर्ण बिट में कैरी का अनुकरण करके दोनों का पूरक प्राप्त करने के लिए 1 जोड़ा जा सकता है। उदाहरण के लिए:
0110 0100 [x, equals decimal 100]
- 0001 0110 [y, equals decimal 22]
योग बन जाता है:
0110 0100 [x]
+ 1110 1001 [ones' complement of y = 1111 1111 - y]
+ 1 [to get the two's complement = 1 0000 0000 - y]
———————————
10100 1110 [x + 1 0000 0000 - y]
आरंभिक 1 को हटाने पर उत्तर मिलता है: 0100 1110 (दशमलव 78 के बराबर)
ऋणात्मक संख्या निरूपण
पूरक की विधि सामान्यतः मानती है कि ऑपरेंड सकारात्मक हैं और y ≤ x, तार्किक बाधाएं दी गई हैं कि सही विधि से पूर्णांकों को जोड़ना और घटाना सामान्यतः संकेतों की तुलना करके, दोनों को जोड़कर या बड़े से छोटे को घटाकर किया जाता है, और परिणाम सही होता है संकेत।
आइए देखें कि यदि x < y हो तो क्या होता है। उस स्थिति में, जोड़ने के बाद काटने के लिए 1 अंक नहीं होगा से कम होगा . उदाहरण के लिए, (दशमलव में):
185 [x] - 329 [y]
y को पूरक करने और जोड़ने पर मिलता है:
185 [x] + 670 [nines' complement of y] +1 ————— 856
इस बिंदु पर, घटाकर गणना पूरी करने का कोई सरल विधि नहीं है (इस स्थिति में 1000); कोई भी अग्रणी 1 को अनदेखा नहीं कर सकता है। अपेक्षित उत्तर -144 है, जो उतना दूर नहीं है जितना लगता है; 856, 144 का दहाई का पूरक है। इस कथन को कई विधियों से संबोधित किया जा सकता है:
- कथन पर ध्यान न दें. यह उचित है यदि कोई व्यक्ति गणना उपकरण चला रहा है जो नकारात्मक संख्याओं का समर्थन नहीं करता है क्योंकि गणना से पहले दो ऑपरेंड की तुलना करना ताकि उन्हें उचित क्रम में अंकित किया जा सके, और यह सत्यापित करना कि परिणाम उचित है, मनुष्यों के लिए ऐसा करना सरल है .
- 1000 में से 856 घटाने के लिए उसी विधि का उपयोग करें, और फिर परिणाम में नकारात्मक चिह्न जोड़ें है।
- ऋणात्मक संख्याओं को उनके धनात्मक समकक्षों के मूलांक पूरक के रूप में निरूपित करें। से कम संख्या सकारात्मक माने जाते हैं; बाकी को नकारात्मक माना जाता है (और उनका परिमाण मूलांक पूरक लेकर प्राप्त किया जा सकता है)। यह सम मूलांकों के लिए सबसे अच्छा काम करता है क्योंकि चिह्न का निर्धारण पहले अंक को देखकर किया जा सकता है। उदाहरण के लिए, दस के पूरक अंकन में संख्याएँ सकारात्मक हैं यदि पहला अंक 0, 1, 2, 3, या 4 है, और यदि 5, 6, 7, 8, या 9 है तो नकारात्मक हैं। और यह पहले से ही बाइनरी में बहुत अच्छी तरह से काम करता है बिट को साइन बिट माना जा सकता है: यदि साइन बिट 0 है तो संख्या सकारात्मक है और यदि 1 है तो नकारात्मक है। वास्तव में, हस्ताक्षरित संख्याओं को दर्शाने के लिए अधिकांश आधुनिक कंप्यूटरों में दो के पूरक का उपयोग किया जाता है।
- यदि सबसे महत्वपूर्ण अंक (एक संकेत है कि x, y से कम था) का कोई उपयोग नहीं होने पर परिणाम को पूरक करें। ऑपरेंड की तुलना और अदला-बदली करने की तुलना में इसे डिजिटल सर्किट के साथ प्रयुक्त करना सरल है। किन्तु चूंकि मूलांक पूरक लेने के लिए 1 जोड़ने की आवश्यकता होती है, इसलिए इसे सीधे करना कठिन है। इस जोड़ से बचने के लिए तरकीब का उपयोग किया जा सकता है: घटाते समय कैरी आउट को सदैव सबसे कम महत्वपूर्ण अंक में सेट करने के अतिरिक्त, सबसे महत्वपूर्ण अंक के कैरी आउट को कम से कम महत्वपूर्ण अंक में कैरी इनपुट के रूप में उपयोग किया जाता है (एक ऑपरेशन जिसे कहा जाता है) । इसलिए यदि y ≤ x है, तो सबसे महत्वपूर्ण अंक जिसे सामान्यतः नजरअंदाज कर दिया जाता है, जिसको जोड़ दिया जाता है, जिससे सही परिणाम प्राप्त होता है। और यदि नहीं, तो 1 नहीं जोड़ा जाता है और परिणाम उत्तर के मूलांक पूरक से कम होता है, या घटा हुआ मूलांक पूरक होता है, जिसे प्राप्त करने के लिए जोड़ की आवश्यकता नहीं होती है। इस पद्धति का उपयोग उन कंप्यूटरों द्वारा किया जाता है जो हस्ताक्षरित संख्याओं को दर्शाने के लिए संकेत-और-परिमाण का उपयोग करते हैं।
व्यावहारिक उपयोग
कई यांत्रिक कैलकुलेटरों में गियर को पीछे की ओर चलाने के विकल्प के रूप में पूरक की विधि का उपयोग किया गया था। उदाहरण के लिए:
- पास्कल के कैलकुलेटर में परिणाम अंकों के दो सेट थे, काला सेट जो सामान्य परिणाम प्रदर्शित करता था और लाल सेट जो नाइन के पूरक को प्रदर्शित करता था। इनमें से सेट को ढकने और दूसरे को प्रदर्शित करने के लिए क्षैतिज स्लैट का उपयोग किया गया था। घटाने के लिए, लाल अंकों को प्रदर्शित किया गया और 0 पर सेट किया गया है। फिर मीनूएंड के नौ के पूरक को अंकित किया गया है। कुछ मशीनों पर इसे पूरक के आंतरिक पहियों का उपयोग करके मिनट में डायल करके किया जा सकता है (अर्थात मिनट के नाइन के पूरक को मानसिक रूप से निर्धारित किए बिना)। पूरक विंडो (लाल सेट) में उस डेटा को प्रदर्शित करने में, ऑपरेटर मीनूएंड के नाइन के पूरक के नाइन के पूरक को देख सकता है, जो कि मीनूएंड है। फिर काले अंकों को प्रदर्शित करने के लिए स्लैट को स्थानांतरित किया गया (जो अब मीनूएंड के नाइन के पूरक को प्रदर्शित करता है) और इसे डायल करके सबट्रेंड को जोड़ा गया था। अंत में, ऑपरेटर को सही उत्तर पढ़ने के लिए स्लैट को फिर से स्थानांतरित करना पड़ा था।
- कंप्टमीटर में प्रत्येक कुंजी पर सामान्य अंकों के साथ-साथ नौ के पूरक अंक छोटे प्रकार में मुद्रित होते थे। घटाने के लिए, ऑपरेटर से मानसिक रूप से सबट्रेंड से 1 घटाने और छोटे अंकों का उपयोग करके परिणाम अंकित करने की अपेक्षा की गई थी। चूंकि पूरक करने से पहले 1 घटाना बाद में 1 जोड़ने के बराबर है, इसलिए ऑपरेटर प्रभावी रूप से सबट्रेंड के दस के पूरक को जोड़ देगा। ऑपरेटर को उत्तर के सबसे बाएं अंक के अनुरूप घटाव कटऑफ टैब को भी दबाकर रखना होगा। इस टैब ने कैरी को इसके आगे फैलने से रोका, परिणाम से प्रारंभिक 1 को हटाने की कॉम्पटोमीटर की विधि है।[2]
- कंप्यूटर ने घटाव के लिए पूरक की विधि का उपयोग किया था, और इसे उपयोगकर्ता से छिपाने में कामयाब रहा था। डिवाइस के किनारे अंक इनपुट स्लाइड का उपयोग करके नंबर अंकित किए गए थे। प्रत्येक स्लाइड पर संख्या को गियरिंग तंत्र द्वारा परिणाम काउंटर में जोड़ा गया था, जो घूर्णन सोपानक ड्रम (a.k.a. स्टेप ड्रम) पर कैम लगाता था। उपकरण के शीर्ष पर क्रैंक का उपयोग करके ड्रम को घुमाया जाता था। क्रैंक चालू होने पर प्रत्येक अंक द्वारा सामना किए गए कैम की संख्या उस अंक के मूल्य से निर्धारित की जाती थी। उदाहरण के लिए, यदि स्लाइड को उसकी 6वीं स्थिति पर सेट किया जाता है, जिससे उस स्थिति के अनुरूप ड्रम के चारों ओर 6 कैमों की पंक्ति सामने आएगी। घटाने के लिए, ड्रम को घुमाने से पहले थोड़ा सा स्थानांतरित किया गया, जिससे कैम की अलग पंक्ति स्थिति में आ गई थी। इस वैकल्पिक पंक्ति में अंकों का नौ पूरक सम्मिलित था। इस प्रकार, 6 कैमों की पंक्ति जो जोड़ने की स्थिति में थी, अब 3 कैमों वाली पंक्ति थी। स्थानांतरित ड्रम में अतिरिक्त कैम भी सम्मिलित था जिसने परिणाम में 1 जोड़ा (जैसा कि पूरक की विधि के लिए आवश्यक था)। सदैव उपस्थित दहाई का पूरक अतिप्रवाह 1, जो परिणाम रजिस्टर के सबसे महत्वपूर्ण अंक से परे किया गया था, वास्तव में, खारिज कर दिया गया था।
कंप्यूटर में
हस्ताक्षरित संख्याओं के लिए उपयोग किए जाने वाले प्रतिनिधित्व की परवाह किए बिना, डिजिटल कंप्यूटरों में पूरक की विधि का उपयोग सर्वव्यापी है। चूँकि, आवश्यक सर्किटरी प्रतिनिधित्व पर निर्भर करती है:
- यदि दो के पूरक प्रतिनिधित्व का उपयोग किया जाता है, जिससे घटाव के लिए केवल सबट्रेंड के बिट्स को उल्टा करना और कैरी को सबसे दाहिने बिट में सेट करना आवश्यक है।
- किसी के पूरक प्रतिनिधित्व का उपयोग करने के लिए सबट्रेंड के बिट्स को उलटने और सबसे महत्वपूर्ण बिट के कैरी आउट को कम से कम महत्वपूर्ण बिट (एंड-अराउंड कैरी) के कैरी आउट से जोड़ने की आवश्यकता होती है।
- साइन-परिमाण प्रतिनिधित्व का उपयोग करने के लिए केवल सबट्रेंड के साइन बिट को पूरक करने और जोड़ने की आवश्यकता होती है, किन्तु जोड़/घटाव तर्क को साइन बिट्स की तुलना करने की आवश्यकता होती है, यदि वे अलग-अलग हैं तो इनपुट में से को पूरक करें, एंड-अराउंड कैरी प्रयुक्त करें, और पूरक करें परिणाम यदि सबसे महत्वपूर्ण बिट से कोई कैरी नहीं था।
मैन्युअल उपयोग
जब लेखांकन पुस्तकें हाथ से लिखी जाती थीं तो त्रुटियों को ठीक करने के लिए पूरक की विधि का उपयोग किया जाता था। संख्याओं के कॉलम से प्रविष्टि को हटाने के लिए, अकाउंटेंट घटाने के लिए संख्या के दस के पूरक के साथ नई प्रविष्टि जोड़ सकता है। इसकी विशेष स्थिति को दर्शाने के लिए इस प्रविष्टि के अंकों के ऊपर बार जोड़ा गया था। फिर सही परिणाम प्राप्त करने के लिए आंकड़ों के पूरे कॉलम को जोड़ना संभव हो गया।
मुद्रा के आधार की पूर्णांक शक्ति तक बढ़ाए गए 1 के एकल मूल्यवर्ग में मुद्रा से खरीदारी के लिए परिवर्तन करने वाले कैशियर के लिए राशि को प्रयुक्त करना सरल है। दशमलव मुद्राओं के लिए जो 10, 100, 1,000, आदि होंगी, उदा. $10.00 का बिल था
ग्रेड स्कूल शिक्षा में
ग्रेड स्कूलों में, छात्रों को कभी-कभी मानसिक अंकगणित में उपयोगी शॉर्टकट के रूप में पूरक की विधि सिखाई जाती है।[3] घटाव सबट्रेंड के दहाई के पूरक को जोड़कर किया जाता है, जो नौ का पूरक प्लस 1 है। इस जोड़ के परिणाम का उपयोग तब किया जाता है जब यह स्पष्ट हो कि अंतर सकारात्मक होगा, अन्यथा जोड़ के परिणाम के दहाई के पूरक का उपयोग किया जाता है। इसे नकारात्मक के रूप में चिह्नित किया गया था। यही तकनीक जोड़ने वाली मशीन पर घटाने के लिए भी काम करती है।
यह भी देखें
- दो का पूरक - बाइनरी कंप्यूटर के लिए विशेष स्थिति
संदर्भ
- ↑ Florida Tech
- ↑ Easy Instructions for Operation the Controlled Key Comptometer, Comptometer Division, Felt and Tarrant Mfg. Co., Chicago, 1917, p. 12
- ↑ Carl Barnett Allendoerfer (1971). प्राथमिक विद्यालय के शिक्षकों के लिए अंकगणित और ज्यामिति के सिद्धांत. Macmillan.