इष्टतम सबस्ट्रक्चर: Difference between revisions
(Created page with "Image:Shortest path optimal substructure.svg|200px|thumb|चित्रा 1. इष्टतम सबस्ट्रक्चर का उपयोग करके स...") |
No edit summary |
||
Line 1: | Line 1: | ||
[[Image:Shortest path optimal substructure.svg|200px|thumb|चित्रा 1. इष्टतम | [[Image:Shortest path optimal substructure.svg|200px|thumb|चित्रा 1. इष्टतम उपसंरचना का उपयोग करके सबसे छोटा रास्ता ढूँढना। संख्याएँ पथ की लंबाई दर्शाती हैं; सीधी रेखाएँ सिंगल एज (ग्राफ़ थ्योरी) को दर्शाती हैं, लहरदार रेखाएँ सबसे छोटे पथ (ग्राफ़ थ्योरी) को दर्शाती हैं, यानी, ऐसे अन्य कोने भी हो सकते हैं जो यहाँ नहीं दिखाए गए हैं।]][[कंप्यूटर विज्ञान]] में, एक समस्या को इष्टतम उपसंरचना कहा जाता है यदि इसके उप-समस्याओं के इष्टतम समाधान से एक इष्टतम समाधान का निर्माण किया जा सकता है। इस संपत्ति का उपयोग किसी समस्या के लिए लालची एल्गोरिदम की उपयोगिता निर्धारित करने के लिए किया जाता है।<ref name=cormen>{{cite book|title=एल्गोरिदम का परिचय|edition=3rd|last1=Cormen|first1=Thomas H. |last2=Leiserson |first2=Charles E. |last3=Rivest|first3=Ronald L. |last4= Stein |first4=Clifford|date=2009 |isbn=978-0-262-03384-8|publisher=[[MIT Press]]|authorlink1=Thomas H. Cormen |authorlink2=Charles E. Leiserson|authorlink3=Ron Rivest |authorlink4=Clifford Stein}}</ref> | ||
<!-- A special case of optimal substructure is the case where a subproblem S<sub>ab</sub> has an activity P<sub>y</sub>, then it should contain optimal solutions to subproblems S<sub>ay</sub> and S<sub>yb</sub>. --> <!-- *TODO: Add Recursion, misc. --> | |||
ऑप्टिमाइज़ेशन (गणित) के लिए [[गतिशील प्रोग्रामिंग]] के अनुप्रयोग में, [[रिचर्ड बेलमैन]] का [[बेलमैन समीकरण]] # बेलमैन का इष्टतमता का सिद्धांत इस विचार पर आधारित है कि कुछ | सामान्यतः, एक [[लालची एल्गोरिदम]] का उपयोग इष्टतम उपसंरचना के साथ समस्या को हल करने के लिए किया जाता है यदि यह प्रेरण द्वारा सिद्ध किया जा सकता है कि यह प्रत्येक चरण में इष्टतम है।<ref name="cormen" /> अन्यथा, बशर्ते समस्या अतिव्यापी उप-समस्याओं को भी प्रदर्शित करे, '''विभाजित करें और जीतें एल्गोरिदम |''' विभाजित करें और जीतें विधियों या [[गतिशील प्रोग्रामिंग]] का उपयोग किया जा सकता है। यदि कोई उपयुक्त लालची एल्गोरिदम नहीं हैं और समस्या अतिव्यापी उप-समस्याओं को प्रदर्शित करने में विफल रहती है, तो समाधान स्थान की अधिकांशतः एक लंबी लेकिन सीधी खोज सबसे अच्छा विकल्प है। <!-- A special case of optimal substructure is the case where a subproblem S<sub>ab</sub> has an activity P<sub>y</sub>, then it should contain optimal solutions to subproblems S<sub>ay</sub> and S<sub>yb</sub>. --> <!-- *TODO: Add Recursion, misc. --> | ||
ऑप्टिमाइज़ेशन (गणित) के लिए [[गतिशील प्रोग्रामिंग]] के अनुप्रयोग में, [[रिचर्ड बेलमैन]] का [[बेलमैन समीकरण]] # बेलमैन का इष्टतमता का सिद्धांत इस विचार पर आधारित है कि कुछ प्रारंभिक अवधि T से कुछ समाप्ति अवधि T तक एक गतिशील अनुकूलन समस्या को हल करने के लिए, एक को स्पष्ट रूप से करना होगा बाद की तिथियों से प्रारंभ होने वाली उप-समस्याओं को हल करें, जहां t<s<T। यह इष्टतम उपसंरचना का एक उदाहरण है। इष्टतमता के सिद्धांत का उपयोग बेलमैन समीकरण को प्राप्त करने के लिए किया जाता है, जो दर्शाता है कि T से प्रारंभ होने वाली समस्या का मान S से प्रारंभ होने वाली समस्या के मूल्य से कैसे संबंधित है। | |||
== उदाहरण == | == उदाहरण == | ||
कार द्वारा दो शहरों के बीच यात्रा करने के लिए सबसे छोटी पथ समस्या खोजने पर विचार करें, जैसा कि चित्र 1 में दिखाया गया है। इस तरह के एक उदाहरण से इष्टतम उपसंरचना प्रदर्शित होने की संभावना है। अर्थात्, यदि सिएटल से लॉस एंजिल्स का सबसे छोटा मार्ग पोर्टलैंड और फिर सैक्रामेंटो से होकर | कार द्वारा दो शहरों के बीच यात्रा करने के लिए सबसे छोटी पथ समस्या खोजने पर विचार करें, जैसा कि चित्र 1 में दिखाया गया है। इस तरह के एक उदाहरण से इष्टतम उपसंरचना प्रदर्शित होने की संभावना है। अर्थात्, यदि सिएटल से लॉस एंजिल्स का सबसे छोटा मार्ग पोर्टलैंड और फिर सैक्रामेंटो से होकर निकलता है, तो पोर्टलैंड से लॉस एंजिल्स का सबसे छोटा मार्ग सैक्रामेंटो से भी गुजरना होगा। यही है, पोर्टलैंड से लॉस एंजिल्स तक कैसे पहुंचे की समस्या सिएटल से लॉस एंजिल्स तक कैसे पहुंचे की समस्या के अंदर निहित है। (ग्राफ में लहरदार रेखाएं उप-समस्याओं के समाधान का प्रतिनिधित्व करती हैं।) | ||
एक ऐसी समस्या के उदाहरण के रूप में, जो इष्टतम आधारभूत संरचना प्रदर्शित करने की संभावना नहीं है, ब्यूनस आयर्स से मास्को तक सबसे सस्ता एयरलाइन टिकट खोजने की समस्या पर विचार करें। भले ही उस टिकट में मियामी और फिर लंदन में स्टॉप | एक ऐसी समस्या के उदाहरण के रूप में, जो इष्टतम आधारभूत संरचना प्रदर्शित करने की संभावना नहीं है, ब्यूनस आयर्स से मास्को तक सबसे सस्ता एयरलाइन टिकट खोजने की समस्या पर विचार करें। भले ही उस टिकट में मियामी और फिर लंदन में स्टॉप सम्मिलित हो, हम यह निष्कर्ष नहीं निकाल सकते कि मियामी से मॉस्को का सबसे सस्ता टिकट लंदन में रुकता है, क्योंकि जिस कीमत पर एयरलाइन एक बहु-उड़ान यात्रा बेचती है, वह सामान्यतः कीमतों का योग नहीं होती है। जिस पर वह यात्रा में व्यक्तिगत उड़ानों की बिक्री करेगा। | ||
== परिभाषा == | == परिभाषा == | ||
इष्टतम उपसंरचना की थोड़ी अधिक औपचारिक परिभाषा दी जा सकती है। एक समस्या को विकल्पों का एक संग्रह होने दें, और प्रत्येक विकल्प की एक संबद्ध लागत, c(a) होने दें। कार्य विकल्पों का एक सेट खोजना है जो | इष्टतम उपसंरचना की थोड़ी अधिक औपचारिक परिभाषा दी जा सकती है। एक समस्या को विकल्पों का एक संग्रह होने दें, और प्रत्येक विकल्प की एक संबद्ध लागत, c(a) होने दें। कार्य विकल्पों का एक सेट खोजना है जो ''c''(''a'') को कम करता है। मान लीजिए कि विकल्प एक सेट का उपसमुच्चय में विभाजन हो सकता है, यानी प्रत्येक विकल्प केवल एक उपसमुच्चय से संबंधित है। मान लीजिए कि प्रत्येक उपसमुच्चय का अपना लागत फलन है। इन लागत कार्यों में से प्रत्येक का न्यूनतम पाया जा सकता है, जैसा कि वैश्विक लागत फलन का न्यूनतम हो सकता है, जो एक ही सबसेट तक सीमित है। यदि ये मिनिमा प्रत्येक उपसमुच्चय के लिए मेल खाते हैं, तो यह लगभग स्पष्ट है कि एक वैश्विक न्यूनतम को विकल्पों के पूर्ण सेट से नहीं चुना जा सकता है, लेकिन केवल उस सेट से बाहर किया जा सकता है जिसमें हमारे द्वारा परिभाषित छोटे, स्थानीय लागत कार्यों की न्यूनतमता सम्मिलित है। यदि स्थानीय कार्यों को कम करना निम्न क्रम की समस्या है, और (विशेष रूप से) यदि, इन कटौती की एक सीमित संख्या के बाद, समस्या तुच्छ हो जाती है, तो समस्या का एक इष्टतम उपसंरचना है। | ||
== इष्टतम | == इष्टतम उपसंरचना के साथ समस्याएं == | ||
* [[सबसे लंबी आम अनुवर्ती समस्या]] | * [[सबसे लंबी आम अनुवर्ती समस्या]] | ||
* [[सबसे लंबे समय तक बढ़ती अनुवर्ती]] | * [[सबसे लंबे समय तक बढ़ती अनुवर्ती]] | ||
Line 18: | Line 20: | ||
* कोई भी समस्या जिसे डायनेमिक प्रोग्रामिंग द्वारा हल किया जा सकता है। | * कोई भी समस्या जिसे डायनेमिक प्रोग्रामिंग द्वारा हल किया जा सकता है। | ||
== इष्टतम | == इष्टतम उपसंरचना के बिना समस्याएं == | ||
* [[सबसे लंबी पथ समस्या]] | * [[सबसे लंबी पथ समस्या]] | ||
* [[जोड़-श्रृंखला घातांक]] | * [[जोड़-श्रृंखला घातांक]] | ||
* सबसे कम लागत वाला एयरलाइन किराया। ऑनलाइन उड़ान खोज का उपयोग करते हुए, हम | * सबसे कम लागत वाला एयरलाइन किराया। ऑनलाइन उड़ान खोज का उपयोग करते हुए, हम अधिकांशतः पाएंगे कि हवाई अड्डे A से हवाई अड्डे B तक की सबसे सस्ती उड़ान में हवाई अड्डे C के माध्यम से एक ही कनेक्शन सम्मिलित है, लेकिन हवाई अड्डे A से हवाई अड्डे C तक की सबसे सस्ती उड़ान में कुछ अन्य हवाई अड्डे D के माध्यम से एक कनेक्शन सम्मिलित है। चुकीं, यदि समस्या एक पैरामीटर के रूप में लेओवर्स की अधिकतम संख्या लेती है, तो समस्या में इष्टतम उपसंरचना होता है। A से B तक की सबसे सस्ती उड़ान जिसमें अधिकांश k लेओवर सम्मिलित हैं या तो सीधी उड़ान है; या A से कुछ एयरपोर्ट C के लिए सबसे सस्ती उड़ान जिसमें 0≤t<k के साथ कुछ पूर्णांक t के लिए अधिकतम t ठहराव सम्मिलित है, साथ ही C से B तक की सबसे सस्ती उड़ान जिसमें अधिकांश k−1−t ठहराव सम्मिलित हैं। | ||
== यह भी देखें == | == यह भी देखें == |
Revision as of 11:18, 31 May 2023
कंप्यूटर विज्ञान में, एक समस्या को इष्टतम उपसंरचना कहा जाता है यदि इसके उप-समस्याओं के इष्टतम समाधान से एक इष्टतम समाधान का निर्माण किया जा सकता है। इस संपत्ति का उपयोग किसी समस्या के लिए लालची एल्गोरिदम की उपयोगिता निर्धारित करने के लिए किया जाता है।[1]
सामान्यतः, एक लालची एल्गोरिदम का उपयोग इष्टतम उपसंरचना के साथ समस्या को हल करने के लिए किया जाता है यदि यह प्रेरण द्वारा सिद्ध किया जा सकता है कि यह प्रत्येक चरण में इष्टतम है।[1] अन्यथा, बशर्ते समस्या अतिव्यापी उप-समस्याओं को भी प्रदर्शित करे, विभाजित करें और जीतें एल्गोरिदम | विभाजित करें और जीतें विधियों या गतिशील प्रोग्रामिंग का उपयोग किया जा सकता है। यदि कोई उपयुक्त लालची एल्गोरिदम नहीं हैं और समस्या अतिव्यापी उप-समस्याओं को प्रदर्शित करने में विफल रहती है, तो समाधान स्थान की अधिकांशतः एक लंबी लेकिन सीधी खोज सबसे अच्छा विकल्प है।
ऑप्टिमाइज़ेशन (गणित) के लिए गतिशील प्रोग्रामिंग के अनुप्रयोग में, रिचर्ड बेलमैन का बेलमैन समीकरण # बेलमैन का इष्टतमता का सिद्धांत इस विचार पर आधारित है कि कुछ प्रारंभिक अवधि T से कुछ समाप्ति अवधि T तक एक गतिशील अनुकूलन समस्या को हल करने के लिए, एक को स्पष्ट रूप से करना होगा बाद की तिथियों से प्रारंभ होने वाली उप-समस्याओं को हल करें, जहां t<s<T। यह इष्टतम उपसंरचना का एक उदाहरण है। इष्टतमता के सिद्धांत का उपयोग बेलमैन समीकरण को प्राप्त करने के लिए किया जाता है, जो दर्शाता है कि T से प्रारंभ होने वाली समस्या का मान S से प्रारंभ होने वाली समस्या के मूल्य से कैसे संबंधित है।
उदाहरण
कार द्वारा दो शहरों के बीच यात्रा करने के लिए सबसे छोटी पथ समस्या खोजने पर विचार करें, जैसा कि चित्र 1 में दिखाया गया है। इस तरह के एक उदाहरण से इष्टतम उपसंरचना प्रदर्शित होने की संभावना है। अर्थात्, यदि सिएटल से लॉस एंजिल्स का सबसे छोटा मार्ग पोर्टलैंड और फिर सैक्रामेंटो से होकर निकलता है, तो पोर्टलैंड से लॉस एंजिल्स का सबसे छोटा मार्ग सैक्रामेंटो से भी गुजरना होगा। यही है, पोर्टलैंड से लॉस एंजिल्स तक कैसे पहुंचे की समस्या सिएटल से लॉस एंजिल्स तक कैसे पहुंचे की समस्या के अंदर निहित है। (ग्राफ में लहरदार रेखाएं उप-समस्याओं के समाधान का प्रतिनिधित्व करती हैं।)
एक ऐसी समस्या के उदाहरण के रूप में, जो इष्टतम आधारभूत संरचना प्रदर्शित करने की संभावना नहीं है, ब्यूनस आयर्स से मास्को तक सबसे सस्ता एयरलाइन टिकट खोजने की समस्या पर विचार करें। भले ही उस टिकट में मियामी और फिर लंदन में स्टॉप सम्मिलित हो, हम यह निष्कर्ष नहीं निकाल सकते कि मियामी से मॉस्को का सबसे सस्ता टिकट लंदन में रुकता है, क्योंकि जिस कीमत पर एयरलाइन एक बहु-उड़ान यात्रा बेचती है, वह सामान्यतः कीमतों का योग नहीं होती है। जिस पर वह यात्रा में व्यक्तिगत उड़ानों की बिक्री करेगा।
परिभाषा
इष्टतम उपसंरचना की थोड़ी अधिक औपचारिक परिभाषा दी जा सकती है। एक समस्या को विकल्पों का एक संग्रह होने दें, और प्रत्येक विकल्प की एक संबद्ध लागत, c(a) होने दें। कार्य विकल्पों का एक सेट खोजना है जो c(a) को कम करता है। मान लीजिए कि विकल्प एक सेट का उपसमुच्चय में विभाजन हो सकता है, यानी प्रत्येक विकल्प केवल एक उपसमुच्चय से संबंधित है। मान लीजिए कि प्रत्येक उपसमुच्चय का अपना लागत फलन है। इन लागत कार्यों में से प्रत्येक का न्यूनतम पाया जा सकता है, जैसा कि वैश्विक लागत फलन का न्यूनतम हो सकता है, जो एक ही सबसेट तक सीमित है। यदि ये मिनिमा प्रत्येक उपसमुच्चय के लिए मेल खाते हैं, तो यह लगभग स्पष्ट है कि एक वैश्विक न्यूनतम को विकल्पों के पूर्ण सेट से नहीं चुना जा सकता है, लेकिन केवल उस सेट से बाहर किया जा सकता है जिसमें हमारे द्वारा परिभाषित छोटे, स्थानीय लागत कार्यों की न्यूनतमता सम्मिलित है। यदि स्थानीय कार्यों को कम करना निम्न क्रम की समस्या है, और (विशेष रूप से) यदि, इन कटौती की एक सीमित संख्या के बाद, समस्या तुच्छ हो जाती है, तो समस्या का एक इष्टतम उपसंरचना है।
इष्टतम उपसंरचना के साथ समस्याएं
- सबसे लंबी आम अनुवर्ती समस्या
- सबसे लंबे समय तक बढ़ती अनुवर्ती
- सबसे लंबा मुरजबंध संबंधी सबस्ट्रिंग
- सबसे छोटा_पथ_समस्या#सभी-जोड़े_सबसे छोटा_पथ|सभी-जोड़े सबसे छोटा रास्ता
- कोई भी समस्या जिसे डायनेमिक प्रोग्रामिंग द्वारा हल किया जा सकता है।
इष्टतम उपसंरचना के बिना समस्याएं
- सबसे लंबी पथ समस्या
- जोड़-श्रृंखला घातांक
- सबसे कम लागत वाला एयरलाइन किराया। ऑनलाइन उड़ान खोज का उपयोग करते हुए, हम अधिकांशतः पाएंगे कि हवाई अड्डे A से हवाई अड्डे B तक की सबसे सस्ती उड़ान में हवाई अड्डे C के माध्यम से एक ही कनेक्शन सम्मिलित है, लेकिन हवाई अड्डे A से हवाई अड्डे C तक की सबसे सस्ती उड़ान में कुछ अन्य हवाई अड्डे D के माध्यम से एक कनेक्शन सम्मिलित है। चुकीं, यदि समस्या एक पैरामीटर के रूप में लेओवर्स की अधिकतम संख्या लेती है, तो समस्या में इष्टतम उपसंरचना होता है। A से B तक की सबसे सस्ती उड़ान जिसमें अधिकांश k लेओवर सम्मिलित हैं या तो सीधी उड़ान है; या A से कुछ एयरपोर्ट C के लिए सबसे सस्ती उड़ान जिसमें 0≤t<k के साथ कुछ पूर्णांक t के लिए अधिकतम t ठहराव सम्मिलित है, साथ ही C से B तक की सबसे सस्ती उड़ान जिसमें अधिकांश k−1−t ठहराव सम्मिलित हैं।
यह भी देखें
- गतिशील प्रोग्रामिंग
- इष्टतमता का सिद्धांत
- फूट डालो और जीतो एल्गोरिथ्म
संदर्भ
- ↑ 1.0 1.1 Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2009). एल्गोरिदम का परिचय (3rd ed.). MIT Press. ISBN 978-0-262-03384-8.