K-क्रमबद्ध अनुक्रम: Difference between revisions

From Vigyanwiki
Line 39: Line 39:
=== अनुक्रम की त्रिज्या को आधा करना ===
=== अनुक्रम की त्रिज्या को आधा करना ===


दिया गया ए <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>\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>-क्रमबद्ध अनुक्रम ===
Line 52: Line 52:
दो का विलय <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>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^2</math>, इसकी सामग्री को हटाना पर्याप्त है <math>\alpha^2</math> और इसे संलग्न करें <math>\omega</math>. मामला जहां <math>\alpha^2</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
k/2)</math> और <math>A^2=\max(a^2_i\mid 1\le i\le k/2)</math>, वे सबसे महान हैं <math>k/2</math>-प्रथम
k/2)</math> और <math>A^2=\max(a^2_i\mid 1\le i\le k/2)</math>, वे सबसे महान हैं <math>k/2</math>-प्रथम प्रत्येक सूची के तत्व हैं <math>A^1<A^2</math>, दूसरा स्थान समरूपता के समान है। जहाँ <math>a^1_1,\dots, a^1_{k/2}</math> से <math>\alpha^1</math> हटाओ <math>\{a^2_j\mid 1\le j\le k/2, a^2_j\le
प्रत्येक सूची के तत्व. चलिए मान लेते हैं <math>A^1<A^2</math>, दूसरा मामला समरूपता के समान है। निकालना
A^1\}</math> से <math>\alpha^2</math> <math>\omega</math> में जोड़ें।
<math>a^1_1,\dots, a^1_{k/2}</math> से <math>\alpha^1</math> और हटाओ <math>\{a^2_j\mid 1\le j\le k/2, a^2_j\le
A^1\}</math> से <math>\alpha^2</math> और उन्हें जोड़ें <math>\omega</math>.


=== सॉर्टिंग ए <math>k</math>-क्रमबद्ध अनुक्रम ===
=== सॉर्टिंग ए <math>k</math>-क्रमबद्ध अनुक्रम ===

Revision as of 06:57, 2 August 2023

कंप्यूटर विज्ञान में क्रमबद्ध अनुक्रम, जिसे अधिकतर कमबद्ध अनुक्रम के रूप में जाना जाता है-सॉर्टेड अनुक्रम का एक अनुक्रम है जो लगभग क्रमबद्ध होता है। क्रमबद्ध अनुक्रम से तात्पर्य यह है कि अनुक्रम का कोई भी तत्व उस स्थान से बहुत दूर नहीं है जहाँ वह होता यदि अनुक्रम पूर्णतः क्रमबद्ध है तो यह अभी भी संभव है कि अनुक्रम का कोई भी तत्व उस स्थान पर नहीं है जहां उसे होना चाहिए यदि अनुक्रम पूरी तरह से व्यवस्थित होता।

लगभग क्रमबद्ध क्रम विशेष रूप से तब उपयोगी होते हैं जब तत्व के सही क्रम का कोई महत्व नहीं होता है। उदाहरण के लिए ट्विटर[1] ट्वीट्स को लगभग क्रमबद्ध करें, क्योंकि अधिक सटीकता की आवश्यकता नहीं होती,जबकि सभी कंप्यूटरों को सटीक रूप से सिंक्रनाइज़ करने की असंभवता को देखते हुए, सभी ट्वीट्स को उनके पोस्ट किए जाने के समय के अनुसार सटीक क्रमबद्ध करना असंभव है इस विचार के कारण स्नोफ्लेक आईडी का निर्माण हुआ -सॉर्टिंग एक अनुक्रम के तत्वों को पुन: व्यवस्थित करने का संचालन है जिससे -क्रमबद्ध -सॉर्टिंग अधिकतर सॉर्टिंग से अधिक कुशल होती है। इसी प्रकार, किसी अनुक्रम को क्रमबद्ध करना आसान होता है यदि यह ज्ञात हो कि अनुक्रम -क्रमबद्ध, इसलिए यदि किसी कार्यक्रम पर केवल विचार करने की आवश्यकता होती है तो इनपुट या आउटपुट के रूप में क्रमबद्ध अनुक्रम में -क्रमबद्ध क्रम से समय की बचत हो सकती है।

किसी अनुक्रम की त्रिज्या पूर्व-क्रमबद्धता का एक माप है अर्थात, इसका मान यह इंगित करता है कि पूरी तरह से क्रमबद्ध मान प्राप्त करने के लिए सूची में तत्वों को कितना स्थानांतरित करना होगा ट्वीट्स के उपरोक्त उदाहरण में, जिन्हें दूसरे तक क्रमबद्ध किया गया है,तथा एक सेकंड में ट्वीट्स की संख्या से अनुक्रम सीमित है।

परिभाषा

एक सकारात्मक संख्या दी गई , एक क्रम में बताया गया कि -यदि प्रत्येक के लिए क्रमबद्ध और प्रत्येक के लिए , . अर्थात् अनुक्रम को केवल उन तत्वों के युग्मों के लिए क्रमबद्ध करना होगा जिनकी दूरी कम से कम हो .

अनुक्रम की त्रिज्या , निरूपित [2] या [3] सबसे छोटा है ऐसा कि क्रम है -क्रमबद्ध त्रिज्या पूर्व निर्धारितता की माप है।

किसी अनुक्रम को लगभग क्रमबद्ध या अनुक्रम क्रमबद्ध कहा जाता है इसकी त्रिज्या इसकी लंबाई की तुलना में छोटी होती है।

समतुल्य परिभाषा

एक क्रम है - केवल लंबाई की प्रत्येक सीमा को क्रमबद्ध किया जाता है , -क्रमबद्ध अनुक्रम है।

गुण

लंबाई के सभी क्रम हैं -क्रमबद्ध अर्थात्, . एक क्रम है -लघु किया गया यदि इसे लघु किया गया है तो -क्रमबद्ध अनुक्रम स्वचालित रूप से है -क्रमबद्ध जरूरी नहीं है लेकिन -क्रमबद्ध है।

क्रमबद्ध अनुक्रमों के साथ संबंध

एक क्रम दिया गया है a -क्रमबद्ध क्रम, और इसका क्रम परिवर्तन , अधिकतम है .

प्रारूप

यह तय करना कि कोई अनुक्रम है या नहीं - क्रमबद्ध

यह तय करना कि इसमें क्या अनुक्रम है है -स्ट्रीमिंग प्रारूप द्वारा रैखिक समय और स्थिर स्थान में लघु व जटिलता से क्रमबद्ध किया जा सकता है, जो प्रत्येक के लिए पर्याप्त है , इस पर नज़र रखने के लिए और उसे जॉंचने के लिए यह महत्वपूर्ण है।

किसी अनुक्रम की त्रिज्या की गणना रैखिक समय और स्थान में की जा सकती है, यह इस तथ्य से पता चलता है कि इसे इस प्रकार परिभाषित किया जा सकता है .

अनुक्रम की त्रिज्या को आधा करना

दिया गया ए -क्रमबद्ध क्रम , इसकी गणना करना संभव है -क्रमबद्ध क्रमपरिवर्तन का रैखिक समय और स्थिर स्थान में

सबसे पहले, एक क्रम दिया गया मान लें कि यह अनुक्रम विभाजित है यदि -छोटे तत्व अंदर हैं और यह -बड़े तत्व अंदर हैं . तो अनुक्रम को पुनः व्यवस्थित करने की क्रिया को विभाजन कहते हैं एक विभाजित क्रमपरिवर्तन में इसे पहले माध्यिका ज्ञात करके रैखिक समय में क्रमबद्ध किया जा सकता है और फिर तत्वों को पहले या दूसरे भाग में ले जाना इस पर निर्भर करता है कि वे माध्यिका से छोटे या बड़े हैं।

क्रम तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके प्राप्त किया जा सकता है , फिर तत्वों के ब्लॉकों को उनके स्थान पर विभाजित करके , और उसके बाद फिर से स्थिति पर तत्व प्रत्येक संख्या के लिए जैसे कि उन अनुक्रमों को परिभाषित किया गया है।

इसका उपयोग करते हुए प्रोसेसर जिसमें स्मृति तक कोई साझा पढ़ने और लिखने की पहुंच में नहीं है, जबकि इसमें उसी प्रारूप को लागू किया जा सकता है समय, क्योंकि अनुक्रम का प्रत्येक विभाजन समानांतर में हो सकता है।

दो को मिलाना -क्रमबद्ध अनुक्रम

दो का विलय -क्रमबद्ध अनुक्रम और रैखिक समय और स्थिर स्थान में किया जा सकता है।

सबसे पहले पूर्ववर्ती प्रारूप का उपयोग करके, दोनों अनुक्रमों को रूपांतरित किया जाना चाहिए -क्रमबद्ध अनुक्रम में।

पुनरावर्ती रूप से एक आउटपुट अनुक्रम बनाएं दोनों से सामग्री हटाकर जोड़ दिया जाता है।

अगर दोनों खाली हैं तो लौटना ही काफी है मान लेते हैं खाली है और नहीं , इसकी सामग्री को हटाना पर्याप्त है और इसे संलग्न करें . खाली है और समरूपता से समान है।

आइए उस जगह पर विचार करें जहां न तो खाली है जो इस प्रकार है- और , वे सबसे महान हैं -प्रथम प्रत्येक सूची के तत्व हैं , दूसरा स्थान समरूपता के समान है। जहाँ से हटाओ । से में जोड़ें।

सॉर्टिंग ए -क्रमबद्ध अनुक्रम

-क्रमबद्ध क्रम को ऊपर दिए गए हाफिंग एल्गोरिदम को लागू करके क्रमबद्ध किया जा सकता है बार. यह लेता है अनुक्रमिक मशीन पर समय, या समय का उपयोग प्रोसेसर.

-एक अनुक्रम को क्रमबद्ध करना

प्रत्येक अनुक्रम के बाद से आवश्यक है -सॉर्ट किया गया, यह हॉल्टिंग एल्गोरिदम को लागू करने के लिए पर्याप्त है -समय. इस प्रकार, -सॉर्टिंग की जा सकती है -समय। यह एल्गोरिदम एम-इष्टतम छँटाई -इष्टतम है, यानी, बेहतर सबसे खराब स्थिति वाली जटिलता वाला कोई अनुक्रमिक एल्गोरिदम मौजूद नहीं है।

संदर्भ

  1. @rk. "स्नोफ्लेक की घोषणा". Twitter blog. Retrieved 26 April 2021.
  2. Altman, Tom; Igarashi, Yoshihide (1989-08-25). "Roughly Sorting: Sequential and Parallel Approach". Journal of Information Processing. 12 (2): 154–158.
  3. Estivill-Castro, Vladimir; Wood, Derick (October 1989). "विविधता का एक नया उपाय". Information and Computation. 83 (1): 111–119. doi:10.1016/0890-5401(89)90050-3.