ग्राफ एल्गोरिथ्म

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

  • Vertices- एक ग्राफ में परस्पर जुड़ी वस्तुओं को कोने कहा जाता है। कार्यक्षेत्र के रूप में भी जाना जाता हैnodes

  • Edges - किनारे वे लिंक होते हैं जो कोने जोड़ते हैं।

रेखांकन दो प्रकार के होते हैं -

  • Directed graph - एक निर्देशित ग्राफ में, किनारों की दिशा होती है, यानी, किनारों को एक शीर्ष से दूसरे तक जाना होता है।

  • Undirected graph - एक अप्रत्यक्ष ग्राफ में, किनारों की कोई दिशा नहीं है।

ग्राफ रंग

ग्राफ रंग एक ग्राफ के शीर्षों पर रंगों को असाइन करने की एक विधि है ताकि किसी भी दो आसन्न कोने में एक ही रंग न हो। रंग भरने की कुछ समस्याएं हैं -

  • Vertex coloring - एक ग्राफ के शीर्षों को रंगने का एक तरीका ताकि कोई भी दो आसन्न कोने समान रंग साझा न करें।

  • Edge Coloring - यह प्रत्येक किनारे पर एक रंग निर्दिष्ट करने की विधि है ताकि किसी भी दो किनारों पर समान रंग न हो।

  • Face coloring - यह प्रत्येक चेहरे या एक प्लांटर ग्राफ के क्षेत्र को एक रंग प्रदान करता है ताकि कोई भी दो चेहरे जो एक समान सीमा साझा करते हैं, उनका रंग एक ही हो।

क्रोमेटिक नंबर

रंगीन संख्या एक ग्राफ को रंग देने के लिए आवश्यक रंगों की न्यूनतम संख्या है। उदाहरण के लिए, निम्नलिखित ग्राफ की रंगीन संख्या 3 है।

ग्राफ रंगाई की अवधारणा को समय सारिणी, मोबाइल रेडियो फ्रीक्वेंसी असाइनमेंट, सूडुकू, रजिस्टर आवंटन, और मानचित्रों के रंग तैयार करने में लागू किया जाता है।

ग्राफ रंग के लिए कदम

  • प्रत्येक प्रोसेसर के प्रारंभिक मूल्य को n-आयामी सरणी में 1 पर सेट करें।

  • अब एक शीर्ष पर एक विशेष रंग को असाइन करने के लिए, यह निर्धारित करें कि क्या रंग पहले से ही आसन्न कोने को सौंपा गया है या नहीं।

  • यदि कोई प्रोसेसर आसन्न कोने में समान रंग का पता लगाता है, तो वह सरणी में 0 पर अपना मान सेट करता है।

  • एन 2 तुलना करने के बाद , यदि सरणी का कोई भी तत्व 1 है, तो यह एक वैध रंग है।

ग्राफ़ के रंग के लिए स्यूडोकोड

begin

   create the processors P(i0,i1,...in-1) where 0_iv < m, 0 _ v < n
   status[i0,..in-1] = 1
	
   for j varies from 0 to n-1 do
      begin
		
         for k varies from 0 to n-1 do
         begin
            if aj,k=1 and ij=ikthen
            status[i0,..in-1] =0
         end
			
      end
      ok = ΣStatus
		
   if ok > 0, then display valid coloring exists
   else
      display invalid coloring
      
end

न्यूनतम स्पैनिंग ट्री

एक फैले हुए वृक्ष, जिसके सभी किनारों पर वजन (या लंबाई) का योग ग्राफ G के सभी अन्य संभावित फैले हुए पेड़ों से कम है minimal spanning tree या minimum cost spanningपेड़। निम्नलिखित आंकड़ा एक भारित जुड़ा हुआ ग्राफ दिखाता है।

उपरोक्त ग्राफ के कुछ संभावित फैले हुए पेड़ों को नीचे दिखाया गया है -

उपरोक्त सभी फैले हुए वृक्षों में, आकृति (d) न्यूनतम फैले हुए वृक्ष हैं। ट्रैवलिंग सेल्समैन समस्या में न्यूनतम लागत वाले फैले पेड़ की अवधारणा को लागू किया जाता है, इलेक्ट्रॉनिक सर्किट डिजाइन करना, कुशल नेटवर्क डिजाइन करना और कुशल मार्ग एल्गोरिदम डिजाइन करना।

न्यूनतम लागत फैले पेड़ को लागू करने के लिए, निम्नलिखित दो विधियों का उपयोग किया जाता है -

  • प्राइम का एल्गोरिथम
  • क्रुसकल का एल्गोरिथम

प्राइम का एल्गोरिथम

प्राइम का एल्गोरिथ्म एक लालची एल्गोरिथ्म है, जो हमें एक भारित अप्रत्यक्ष ग्राफ के लिए न्यूनतम फैले हुए पेड़ को खोजने में मदद करता है। यह पहले एक शीर्ष का चयन करता है और उस शीर्ष पर सबसे कम वजन घटना के साथ एक बढ़त पाता है।

प्राइम के एल्गोरिथम के चरण

  • किसी भी शीर्ष का चयन करें, ग्राफ़ G का v 1 कहें ।

  • बढ़त का चयन करें, ई का कहना है 1 जी की ऐसी है कि ई 1 = वी 1 वी 2 और वी 1 ≠ वी 2 और ई 1 वी पर किनारों घटना में कम से कम वजन है 1 ग्राफ जी में

  • अब, चरण 2 के बाद, वी 2 पर न्यूनतम भारित बढ़त घटना का चयन करें ।

  • इसे जारी रखें जब तक n-1 किनारों को चुना नहीं गया है। यहाँn कोने की संख्या है।

न्यूनतम फैले पेड़ है -

क्रुसकल का एल्गोरिथम

क्रुस्कल का एल्गोरिथ्म एक लालची एल्गोरिथ्म है, जो हमें एक जुड़े हुए भारित ग्राफ के लिए न्यूनतम फैले हुए पेड़ को खोजने में मदद करता है, जिससे प्रत्येक चरण पर बढ़ती लागत आर्क्स मिलती है। यह एक न्यूनतम-फैले पेड़ के एल्गोरिथ्म है जो कम से कम संभव वजन का एक किनारा पाता है जो जंगल में किसी भी दो पेड़ों को जोड़ता है।

क्रुशाल के एल्गोरिथ्म के चरण

  • न्यूनतम वजन के एक किनारे का चयन करें; कहते हैं ई 1 ग्राफ़ जी के और ई 1 एक पाश नहीं है।

  • 1 से जुड़ा अगला न्यूनतम भारित किनारा चुनें ।

  • इसे जारी रखें जब तक n-1 किनारों को चुना नहीं गया है। यहाँn कोने की संख्या है।

उपरोक्त ग्राफ का न्यूनतम फैले हुए पेड़ है -

सबसे छोटा पथ एल्गोरिथम

सबसे छोटा पथ एल्गोरिथ्म स्रोत नोड (S) से गंतव्य नोड (D) तक कम से कम लागत पथ खोजने की एक विधि है। यहां, हम मूर के एल्गोरिथ्म पर चर्चा करेंगे, जिसे चौड़ाई प्रथम खोज एल्गोरिदम के रूप में भी जाना जाता है।

मूर की एल्गोरिथ्म

  • स्रोत शीर्ष, S लेबल करें और इसे लेबल करें i और सेट करें i=0

  • शीर्ष पर लेबल किए गए शीर्ष के सभी गैर-लंबित वर्जन ज्ञात करें i। यदि कोई कोने वर्टेक्स से नहीं जुड़े हैं, तो S, तो D, S से कनेक्ट नहीं है। यदि एस से जुड़े कोने हैं, तो उन्हें लेबल करेंi+1

  • यदि D लेबल है, तो चरण 4 पर जाएं, अन्यथा i = i + 1 को बढ़ाने के लिए चरण 2 पर जाएं।

  • सबसे छोटा रास्ता मिलने के बाद रुकें।