K-क्रमबद्ध अनुक्रम: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
{{Orphan|date=October 2021}} | {{Orphan|date=October 2021}} | ||
[[कंप्यूटर विज्ञान]] में क्रमबद्ध अनुक्रम, जिसे अधिकतर | [[कंप्यूटर विज्ञान]] में क्रमबद्ध अनुक्रम, जिसे अधिकतर क्रमबद्ध अनुक्रम और K के रूप में जाना जाता है<math>k</math>-सॉर्टेड अनुक्रम का एक अनुक्रम है जो लगभग क्रमबद्ध होता है। क्रमबद्ध अनुक्रम से तात्पर्य यह है कि अनुक्रम का कोई भी तत्व उस स्थान से बहुत दूर नहीं है जहाँ वह होता यदि अनुक्रम पूर्णतः क्रमबद्ध है तो यह अभी भी संभव है कि अनुक्रम का कोई भी तत्व उस स्थान पर नहीं है जहां उसे होना चाहिए यदि अनुक्रम पूरी तरह से व्यवस्थित होता है। | ||
लगभग क्रमबद्ध क्रम | लगभग क्रमबद्ध क्रम तब उपयोगी होते हैं जब तत्व के सही क्रम का कोई महत्व नहीं होता है। उदाहरण के लिए [[ट्विटर]]<ref name="twitter">{{cite web |last1=@rk |title=स्नोफ्लेक की घोषणा|url=https://blog.twitter.com/engineering/en_us/a/2010/announcing-snowflake.html |website=Twitter blog |access-date=26 April 2021}}</ref> ट्वीट्स को लगभग क्रमबद्ध करें, क्योंकि इसमें अधिक सही होने की आवश्यकता नहीं होती,जबकि सभी कंप्यूटरों को सटीक रूप से विवरण करने की असंभवता को देखते हुए, सभी ट्वीट्स को उनके पोस्ट किए जाने के समय के अनुसार क्रमबद्ध करना असंभव है इस विचार के कारण [[स्नोफ्लेक आईडी]] का निर्माण हुआ <math>k</math>-सॉर्टिंग एक अनुक्रम के तत्वों को पुन: व्यवस्थित करने का संचालन है जिससे <math>k</math>-क्रमबद्ध <math>k</math>- पृथककरण से अधिक कुशल होता है। इसी प्रकार किसी अनुक्रम को क्रमबद्ध करना आसान होता है यदि यह ज्ञात हो कि अनुक्रम <math>k</math>-क्रमबद्ध है, इसलिए यदि किसी कार्यक्रम पर विचार करने की आवश्यकता होती है तो <math>k</math>इनपुट या आउटपुट के रूप में क्रमबद्ध अनुक्रम में <math>k</math>-क्रमबद्ध क्रम से समय की बचत हो सकती है। | ||
किसी अनुक्रम की त्रिज्या पूर्व-क्रमबद्धता की एक माप है अर्थात, इसका मान यह | किसी अनुक्रम की त्रिज्या पूर्व-क्रमबद्धता की एक माप है अर्थात, इसका मान यह दर्शाता है कि पूरी तरह से क्रमबद्ध मान प्राप्त करने के लिए सूची में तत्वों को कितना स्थानांतरित करना होगा ट्वीट्स के उदाहरण में जिन्हें दूसरे तक क्रमबद्ध किया गया है तथा एक सेकंड में ट्वीट्स की संख्या से अनुक्रम सीमित है। | ||
== परिभाषा == | == परिभाषा == | ||
एक सकारात्मक संख्या दी गई <math>k</math>, एक क्रम में <math>[a_1,\dots, a_n]</math> बताया गया कि <math>k</math>-यदि प्रत्येक के लिए क्रमबद्ध <math>1\le i</math> | एक सकारात्मक संख्या दी गई <math>k</math>, एक क्रम में <math>[a_1,\dots, a_n]</math> बताया गया कि <math>k</math>-यदि प्रत्येक के लिए क्रमबद्ध और <math>1\le i</math> प्रत्येक के लिए <math>i+k\le j\le n</math>, <math>a_i\le a_j</math>. अर्थात् अनुक्रम को केवल उन तत्वों के युग्मों के लिए क्रमबद्ध करना होगा जिनकी दूरी कम से कम हो <math>k</math>. | ||
अनुक्रम की त्रिज्या <math>\alpha</math>, निरूपित <math>\text{ROUGH}(\alpha)</math><ref name="altma-Igarashi">{{cite journal |last1=Altman |first1=Tom |last2=Igarashi |first2=Yoshihide |title=Roughly Sorting: Sequential and Parallel Approach |journal=Journal of Information Processing |date=1989-08-25 |volume=12 |issue=2 |pages=154–158 }}</ref> या <math>\text{Par}(\alpha)</math><ref name="Estivill-Castro-Wood">{{cite journal |last1=Estivill-Castro |first1=Vladimir |last2=Wood |first2=Derick |title=विविधता का एक नया उपाय|journal=Information and Computation |date=October 1989 |volume=83 |issue=1 |pages=111–119 |doi=10.1016/0890-5401(89)90050-3|doi-access=free }}</ref> सबसे छोटा है <math>k</math> ऐसा कि क्रम है <math>k</math>-क्रमबद्ध त्रिज्या पूर्व निर्धारितता की माप है। | अनुक्रम की त्रिज्या <math>\alpha</math>, निरूपित <math>\text{ROUGH}(\alpha)</math><ref name="altma-Igarashi">{{cite journal |last1=Altman |first1=Tom |last2=Igarashi |first2=Yoshihide |title=Roughly Sorting: Sequential and Parallel Approach |journal=Journal of Information Processing |date=1989-08-25 |volume=12 |issue=2 |pages=154–158 }}</ref> या <math>\text{Par}(\alpha)</math><ref name="Estivill-Castro-Wood">{{cite journal |last1=Estivill-Castro |first1=Vladimir |last2=Wood |first2=Derick |title=विविधता का एक नया उपाय|journal=Information and Computation |date=October 1989 |volume=83 |issue=1 |pages=111–119 |doi=10.1016/0890-5401(89)90050-3|doi-access=free }}</ref> सबसे छोटा है <math>k</math> ऐसा कि क्रम है <math>k</math>-क्रमबद्ध त्रिज्या पूर्व निर्धारितता की माप है। | ||
Line 17: | Line 17: | ||
=== समतुल्य परिभाषा === | === समतुल्य परिभाषा === | ||
एक क्रम <math>[a_1,\dots, a_n]</math> है <math>k</math>- केवल लंबाई की प्रत्येक सीमा को क्रमबद्ध | एक क्रम <math>[a_1,\dots, a_n]</math> है <math>k</math>- केवल लंबाई की प्रत्येक सीमा को क्रमबद्ध करता है तथा <math>2k+2</math>, <math>[a_i, a_{i+1},\dots, a_{i+2k+2}]</math> <math>k</math>-क्रमबद्ध अनुक्रम है। | ||
== गुण == | == गुण == | ||
Line 33: | Line 33: | ||
यह तय करना कि | इसमें यह तय करना कि क्या अनुक्रम है <math>[a_1,\dots, a_n]</math> <math>k</math>- [[स्ट्रीमिंग एल्गोरिदम|योग्य]] प्रारूप द्वारा [[रैखिक समय]] और स्थिर स्थान में लघु व जटिलता से क्रमबद्ध किया जा [[रैखिक समय|सकता]] है, जो प्रत्येक के लिए पर्याप्त है <math>1\le i < n-k</math>, इस पर नज़र रखने के लिए <math>\max(a_j\mid j\le i)</math> और उसे जॉंचने के लिए यह महत्वपूर्ण है। | ||
किसी अनुक्रम की त्रिज्या की गणना रैखिक समय और | किसी अनुक्रम की त्रिज्या की गणना रैखिक समय और कुछ स्थानों में की जा सकती है, यह इस तथ्य से पता चलता है कि इसे किस प्रकार परिभाषित किया जा सकता है <math>\max(i-j\mid \min(a_k\mid k\ge i) < \max(a_k\mid k\le j))</math>. | ||
=== अनुक्रम की त्रिज्या को आधा करना === | === अनुक्रम की त्रिज्या को आधा करना === | ||
Line 41: | Line 41: | ||
दिया गया ए <math>2k</math>-क्रमबद्ध क्रम <math>\alpha=[a_1,\dots, a_n]</math>, इसकी गणना करना संभव है <math>(k-1)</math>-क्रमबद्ध क्रमपरिवर्तन <math>\alpha'</math> का <math>\alpha</math> रैखिक समय और स्थिर स्थान में | दिया गया ए <math>2k</math>-क्रमबद्ध क्रम <math>\alpha=[a_1,\dots, a_n]</math>, इसकी गणना करना संभव है <math>(k-1)</math>-क्रमबद्ध क्रमपरिवर्तन <math>\alpha'</math> का <math>\alpha</math> रैखिक समय और स्थिर स्थान में | ||
सबसे पहले | सबसे पहले एक क्रम में दिया गया है <math>\beta=[b_1,\dots,b_{2k}]</math> मान लें कि यह अनुक्रम विभाजित है यदि <math>k</math>-छोटे तत्व अंदर हैं <math>[b_1,\dots,b_k]</math> और <math>k</math>-बड़े तत्व अंदर हैं <math>[b_{k+1},\dots, b_{2k}]</math>. तो अनुक्रम को पुनः व्यवस्थित करने की क्रिया को विभाजन कहते हैं <math>\beta</math> एक विभाजित क्रमपरिवर्तन में इसे पहले माध्यिका ज्ञात करके रैखिक समय में क्रमबद्ध करता है और <math>b</math> फिर तत्वों को पहले या दूसरे भाग में ले जाता है यह इस पर निर्भर करता है कि वे माध्यिका से छोटे या बड़े हैं। | ||
क्रम <math>\alpha'</math> तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके प्राप्त किया जा सकता है <math>[2k(i-1)+1, \dots, 2ki]</math>, फिर तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके <math>[2k(i-1)+k+1, \dots, 2ki+k]</math>, और उसके बाद फिर से स्थिति पर तत्व <math>[2k(i-1)+1, \dots, 2ki]</math> प्रत्येक संख्या के लिए <math>i</math> जैसे कि उन अनुक्रमों को परिभाषित किया गया है। | क्रम <math>\alpha'</math> तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके प्राप्त किया जा सकता है <math>[2k(i-1)+1, \dots, 2ki]</math>, फिर तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके <math>[2k(i-1)+k+1, \dots, 2ki+k]</math>, और उसके बाद फिर से स्थिति पर तत्व <math>[2k(i-1)+1, \dots, 2ki]</math> प्रत्येक संख्या के लिए <math>i</math> जैसे कि उन अनुक्रमों को परिभाषित किया गया है। | ||
इसका उपयोग करते हुए <math>\frac{n}{2k}</math> प्रोसेसर जिसमें स्मृति तक कोई साझा पढ़ने और लिखने की पहुंच में नहीं है, जबकि इसमें उसी प्रारूप को लागू किया जा सकता है <math>O(k)</math> समय, | इसका उपयोग करते हुए <math>\frac{n}{2k}</math> प्रोसेसर जिसमें स्मृति तक कोई साझा पढ़ने और लिखने की पहुंच में नहीं है, जबकि इसमें उसी प्रारूप को लागू किया जा सकता है जिसका <math>O(k)</math> समय,अनुक्रम का प्रत्येक विभाजन समानांतर में हो सकता है। | ||
===दो को मिलाना <math>k</math>-क्रमबद्ध अनुक्रम === | ===दो को मिलाना <math>k</math>-क्रमबद्ध अनुक्रम === | ||
{{distinguish|k-way merge algorithm}} | {{distinguish|k-way merge algorithm}} | ||
दो का विलय <math>k</math>-क्रमबद्ध अनुक्रम <math>\alpha^1=[a^1_1,\dots, a^1_n]</math> और <math>\alpha=[a^2_1,\dots, a^2_m]</math> रैखिक समय | दो का विलय <math>k</math>-क्रमबद्ध अनुक्रम <math>\alpha^1=[a^1_1,\dots, a^1_n]</math> और <math>\alpha=[a^2_1,\dots, a^2_m]</math> रैखिक समय स्थिर स्थान में प्रयोग किया जा सकता है। | ||
सबसे पहले पूर्ववर्ती प्रारूप का उपयोग करके, दोनों अनुक्रमों को | सबसे पहले पूर्ववर्ती प्रारूप का उपयोग करके, दोनों अनुक्रमों को <math>k/2</math>-क्रमबद्ध अनुक्रम में रूपांतरित किया जाना चाहिए। | ||
पुनरावर्ती रूप से एक आउटपुट अनुक्रम बनाएं <math>\omega</math> दोनों से सामग्री हटाकर <math>\alpha^i</math> व <math>\omega</math> जोड़ दिया जाता है। | पुनरावर्ती रूप से एक आउटपुट अनुक्रम बनाएं <math>\omega</math> दोनों से सामग्री हटाकर <math>\alpha^i</math> व <math>\omega</math> जोड़ दिया जाता है। | ||
अगर दोनों <math>\alpha^i</math> खाली हैं तो लौटना ही काफी है <math>\omega</math> मान लेते हैं <math>\alpha^1</math> खाली है | अगर दोनों <math>\alpha^i</math> खाली हैं तो लौटना ही काफी है तो <math>\omega</math> मान लेते हैं <math>\alpha^1</math> खाली है <math>\alpha^2</math>, इसकी सामग्री को हटाना पर्याप्त है <math>\alpha^2</math> और इसे संलग्न करें <math>\omega</math>. <math>\alpha^2</math> खाली है और <math>\alpha^1</math> समरूपता से समान है। | ||
आइए उस जगह पर विचार करें जहां न तो <math>\alpha^i</math> खाली है जो इस प्रकार है-<math>A^1=\max(a^1_i\mid 1\le i\le | आइए उस जगह पर विचार करें जहां न तो <math>\alpha^i</math> खाली है जो इस प्रकार है-<math>A^1=\max(a^1_i\mid 1\le i\le |
Revision as of 07:00, 5 August 2023
कंप्यूटर विज्ञान में क्रमबद्ध अनुक्रम, जिसे अधिकतर क्रमबद्ध अनुक्रम और K के रूप में जाना जाता है-सॉर्टेड अनुक्रम का एक अनुक्रम है जो लगभग क्रमबद्ध होता है। क्रमबद्ध अनुक्रम से तात्पर्य यह है कि अनुक्रम का कोई भी तत्व उस स्थान से बहुत दूर नहीं है जहाँ वह होता यदि अनुक्रम पूर्णतः क्रमबद्ध है तो यह अभी भी संभव है कि अनुक्रम का कोई भी तत्व उस स्थान पर नहीं है जहां उसे होना चाहिए यदि अनुक्रम पूरी तरह से व्यवस्थित होता है।
लगभग क्रमबद्ध क्रम तब उपयोगी होते हैं जब तत्व के सही क्रम का कोई महत्व नहीं होता है। उदाहरण के लिए ट्विटर[1] ट्वीट्स को लगभग क्रमबद्ध करें, क्योंकि इसमें अधिक सही होने की आवश्यकता नहीं होती,जबकि सभी कंप्यूटरों को सटीक रूप से विवरण करने की असंभवता को देखते हुए, सभी ट्वीट्स को उनके पोस्ट किए जाने के समय के अनुसार क्रमबद्ध करना असंभव है इस विचार के कारण स्नोफ्लेक आईडी का निर्माण हुआ -सॉर्टिंग एक अनुक्रम के तत्वों को पुन: व्यवस्थित करने का संचालन है जिससे -क्रमबद्ध - पृथककरण से अधिक कुशल होता है। इसी प्रकार किसी अनुक्रम को क्रमबद्ध करना आसान होता है यदि यह ज्ञात हो कि अनुक्रम -क्रमबद्ध है, इसलिए यदि किसी कार्यक्रम पर विचार करने की आवश्यकता होती है तो इनपुट या आउटपुट के रूप में क्रमबद्ध अनुक्रम में -क्रमबद्ध क्रम से समय की बचत हो सकती है।
किसी अनुक्रम की त्रिज्या पूर्व-क्रमबद्धता की एक माप है अर्थात, इसका मान यह दर्शाता है कि पूरी तरह से क्रमबद्ध मान प्राप्त करने के लिए सूची में तत्वों को कितना स्थानांतरित करना होगा ट्वीट्स के उदाहरण में जिन्हें दूसरे तक क्रमबद्ध किया गया है तथा एक सेकंड में ट्वीट्स की संख्या से अनुक्रम सीमित है।
परिभाषा
एक सकारात्मक संख्या दी गई , एक क्रम में बताया गया कि -यदि प्रत्येक के लिए क्रमबद्ध और प्रत्येक के लिए , . अर्थात् अनुक्रम को केवल उन तत्वों के युग्मों के लिए क्रमबद्ध करना होगा जिनकी दूरी कम से कम हो .
अनुक्रम की त्रिज्या , निरूपित [2] या [3] सबसे छोटा है ऐसा कि क्रम है -क्रमबद्ध त्रिज्या पूर्व निर्धारितता की माप है।
किसी अनुक्रम को लगभग क्रमबद्ध या अनुक्रम क्रमबद्ध कहा जाता है इसकी त्रिज्या इसकी लंबाई की तुलना में छोटी होती है।
समतुल्य परिभाषा
एक क्रम है - केवल लंबाई की प्रत्येक सीमा को क्रमबद्ध करता है तथा , -क्रमबद्ध अनुक्रम है।
गुण
लंबाई के सभी क्रम हैं -क्रमबद्ध अर्थात्, . एक क्रम है -लघु किया गया यदि इसे लघु किया गया है तो -क्रमबद्ध अनुक्रम स्वचालित रूप से है -क्रमबद्ध जरूरी नहीं है लेकिन -क्रमबद्ध है।
क्रमबद्ध अनुक्रमों के साथ संबंध
एक क्रम दिया गया है a -क्रमबद्ध क्रम, और इसका क्रम परिवर्तन , अधिकतम है .
प्रारूप
यह तय करना कि कोई अनुक्रम है या नहीं - क्रमबद्ध
इसमें यह तय करना कि क्या अनुक्रम है - योग्य प्रारूप द्वारा रैखिक समय और स्थिर स्थान में लघु व जटिलता से क्रमबद्ध किया जा सकता है, जो प्रत्येक के लिए पर्याप्त है , इस पर नज़र रखने के लिए और उसे जॉंचने के लिए यह महत्वपूर्ण है।
किसी अनुक्रम की त्रिज्या की गणना रैखिक समय और कुछ स्थानों में की जा सकती है, यह इस तथ्य से पता चलता है कि इसे किस प्रकार परिभाषित किया जा सकता है .
अनुक्रम की त्रिज्या को आधा करना
दिया गया ए -क्रमबद्ध क्रम , इसकी गणना करना संभव है -क्रमबद्ध क्रमपरिवर्तन का रैखिक समय और स्थिर स्थान में
सबसे पहले एक क्रम में दिया गया है मान लें कि यह अनुक्रम विभाजित है यदि -छोटे तत्व अंदर हैं और -बड़े तत्व अंदर हैं . तो अनुक्रम को पुनः व्यवस्थित करने की क्रिया को विभाजन कहते हैं एक विभाजित क्रमपरिवर्तन में इसे पहले माध्यिका ज्ञात करके रैखिक समय में क्रमबद्ध करता है और फिर तत्वों को पहले या दूसरे भाग में ले जाता है यह इस पर निर्भर करता है कि वे माध्यिका से छोटे या बड़े हैं।
क्रम तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके प्राप्त किया जा सकता है , फिर तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके , और उसके बाद फिर से स्थिति पर तत्व प्रत्येक संख्या के लिए जैसे कि उन अनुक्रमों को परिभाषित किया गया है।
इसका उपयोग करते हुए प्रोसेसर जिसमें स्मृति तक कोई साझा पढ़ने और लिखने की पहुंच में नहीं है, जबकि इसमें उसी प्रारूप को लागू किया जा सकता है जिसका समय,अनुक्रम का प्रत्येक विभाजन समानांतर में हो सकता है।
दो को मिलाना -क्रमबद्ध अनुक्रम
दो का विलय -क्रमबद्ध अनुक्रम और रैखिक समय स्थिर स्थान में प्रयोग किया जा सकता है।
सबसे पहले पूर्ववर्ती प्रारूप का उपयोग करके, दोनों अनुक्रमों को -क्रमबद्ध अनुक्रम में रूपांतरित किया जाना चाहिए।
पुनरावर्ती रूप से एक आउटपुट अनुक्रम बनाएं दोनों से सामग्री हटाकर व जोड़ दिया जाता है।
अगर दोनों खाली हैं तो लौटना ही काफी है तो मान लेते हैं खाली है , इसकी सामग्री को हटाना पर्याप्त है और इसे संलग्न करें . खाली है और समरूपता से समान है।
आइए उस जगह पर विचार करें जहां न तो खाली है जो इस प्रकार है- और , वे सबसे महान हैं -प्रथम प्रत्येक सूची के तत्व हैं , दूसरा स्थान समरूपता के समान है। जहाँ से हटाओ । से में जोड़ें।
सॉर्टिंग ए -क्रमबद्ध अनुक्रम
ए -क्रमबद्ध क्रम को ऊपर दिए गए हाफिंग प्रारूप को लागू करके क्रमबद्ध किया जा सकता है बार यह लेता है कि अनुक्रमिक मशीन पर समय या समय का उपयोग प्रोसेसर द्वारा किया जाता है।
-एक अनुक्रम को क्रमबद्ध करना
प्रत्येक अनुक्रम के बाद से आवश्यक है -लघु किया गया यह हॉल्टिंग प्रारूप को लागू करने के लिए पर्याप्त है -समय इस प्रकार, -सॉर्टिंग की जा सकती है -समय यह प्रारूप एम-इष्टतम छँटाई है, यानी बेहतर सबसे खराब स्थिति वाली जटिलता वाला कोई अनुक्रमिक प्रारूप एकत्र नहीं है।
संदर्भ
- ↑ @rk. "स्नोफ्लेक की घोषणा". Twitter blog. Retrieved 26 April 2021.
- ↑ Altman, Tom; Igarashi, Yoshihide (1989-08-25). "Roughly Sorting: Sequential and Parallel Approach". Journal of Information Processing. 12 (2): 154–158.
- ↑ Estivill-Castro, Vladimir; Wood, Derick (October 1989). "विविधता का एक नया उपाय". Information and Computation. 83 (1): 111–119. doi:10.1016/0890-5401(89)90050-3.