असतत गणित - रेखांकन पर अधिक

ग्राफ रंग

ग्राफ रंग एक ग्राफ G के प्रत्येक शीर्ष पर रंगों को असाइन करने की प्रक्रिया है जैसे कि कोई आसन्न कोने समान रंग प्राप्त नहीं करते हैं। उद्देश्य यह है कि ग्राफ को रंगते समय रंगों की संख्या कम से कम हो। एक ग्राफ G को रंगने के लिए आवश्यक रंगों की सबसे छोटी संख्या को उस ग्राफ की रंगीन संख्या कहा जाता है। ग्राफ रंग समस्या एक एनपी पूरी समस्या है।

एक ग्राफ रंग करने के लिए विधि

ग्राफ की संख्या के साथ एक ग्राफ G को रंगीन करने के लिए आवश्यक कदम इस प्रकार हैं -

Step 1 - ग्राफ के शीर्षों को किसी क्रम में व्यवस्थित करें।

Step 2 - पहले वर्टेक्स चुनें और इसे पहले रंग से रंगें।

Step 3- अगला शीर्ष चुनें और इसे सबसे कम संख्या वाले रंग के साथ रंग दें जो इसके बगल में किसी भी कोने पर रंगीन नहीं किया गया है। यदि सभी आसन्न कोने इस रंग से रंगे हैं, तो इसे एक नया रंग प्रदान करें। इस चरण को दोहराएं जब तक कि सभी कोने रंगीन न हों।

Example

उपरोक्त आंकड़ों में, पहले शीर्ष पर $ एक $ लाल रंग का है। जैसा कि वर्टेक्स के आसन्न कोने फिर से सटे हुए हैं, वर्टेक्स $ बी $ और वर्टेक्स $ डी $ क्रमशः अलग-अलग रंग, हरे और नीले रंग से रंगे हैं। तब वर्टेक्स $ c $ लाल रंग का होता है क्योंकि $ c $ $ का कोई समीपस्थ वर्कट लाल नहीं होता। इसलिए, हम ग्राफ को 3 रंगों से रंग सकते हैं। इसलिए, ग्राफ की गुणात्मक संख्या 3 है।

ग्राफ रंग के अनुप्रयोग

ग्राफ रंग के कुछ अनुप्रयोगों में शामिल हैं -

  • आवंटन आवंटित करें
  • नक्शा रंग
  • Bipartite Graph जाँच
  • मोबाइल रेडियो फ्रीक्वेंसी असाइनमेंट
  • टाइम टेबल बनाना आदि।

ग्राफ ट्रैवर्सल

ग्राफ़ ट्रैवर्सल किसी व्यवस्थित क्रम में ग्राफ़ के सभी कोने पर जाने की समस्या है। एक ग्राफ को पार करने के लिए मुख्य रूप से दो तरीके हैं।

  • पहले चौड़ाई खोजो
  • गहराई पहली खोज

पहले चौड़ाई खोजो

चौड़ाई प्रथम खोज (बीएफएस) ग्राफ $ जी $ के स्तर -0 वर्टेक्स $ X से शुरू होती है। फिर हम उन सभी शीर्षों पर जाते हैं जो $ X $ के पड़ोसी हैं। दौरा करने के बाद, हम "विज़िट किए गए" के रूप में लंबों को चिह्नित करते हैं और उन्हें स्तर -1 में रखते हैं। फिर हम लेवल -1 वर्टिकल से शुरू करते हैं और हर लेवल -1 वर्टेक्स वगैरह पर भी यही तरीका लागू करते हैं। ग्राफ़ के प्रत्येक शीर्ष पर जाने पर BFS ट्रैवर्सल समाप्त हो जाता है।

BFS Algorithm

अवधारणा यह है कि पड़ोसी कोने के अन्य पड़ोसी कोने पर जाने से पहले सभी पड़ोसी कोने पर जाएं।

  • "रेडी" के रूप में सभी नोड्स की प्रारंभिक स्थिति।

  • स्रोत शीर्ष को एक कतार में रखें और इसकी स्थिति को "प्रतीक्षा" में बदलें।

  • कतार खाली होने तक निम्नलिखित दो चरणों को दोहराएं -

    • कतार से पहला शीर्ष निकालें और इसे "देखे गए" के रूप में चिह्नित करें।

    • हटाए गए शीर्ष के सभी पड़ोसियों को कतार में पीछे जोड़ें जिनकी स्थिति "रेडी" है। उनकी स्थिति को "प्रतीक्षा" के रूप में चिह्नित करें।

Problem

आइए हम एक ग्राफ लेते हैं (सोर्स वर्टेक्स 'ए') है और ट्रैवर्सल ऑर्डर का पता लगाने के लिए बीएफएस एल्गोरिदम लागू करते हैं।

Solution -

  • "तैयार" सभी कोने की प्रारंभिक स्थिति।

  • रखो एक कतार में और "प्रतीक्षा कर रहा है" करने के लिए अपनी स्थिति को बदलने।

  • निकालें एक कतार से, के रूप में "देखे जाने वाले" में चिह्नित करें।

  • कतार के अंत में "रेडी" राज्य बी, डी और में एक पड़ोसी जोड़ें और उन्हें "प्रतीक्षा" के रूप में चिह्नित करें।

  • कतार से b निकालें , इसे "देखे गए" के रूप में चिह्नित करें, कतार के अंत में अपना "रेडी" पड़ोसी c लगाएं और c "प्रतीक्षा" के रूप में चिह्नित करें ।

  • D को कतार से निकालें और इसे "विज़िट" के रूप में चिह्नित करें। "रेडी" राज्य में इसका कोई पड़ोसी नहीं है।

  • कतार से निकालें और इसे "देखे गए" के रूप में चिह्नित करें। "रेडी" राज्य में इसका कोई पड़ोसी नहीं है।

  • C को कतार से निकालें और इसे "विज़िट" के रूप में चिह्नित करें। "रेडी" राज्य में इसका कोई पड़ोसी नहीं है।

  • कतार खाली है इसलिए रुक जाओ।

तो ट्रैवर्सल ऑर्डर है -

$ a \ rightarrow b \ rightarrow d \ rightarrow e \ rightarrow c $

ट्रैवर्सल के वैकल्पिक आदेश हैं -

$ a \ rightarrow b \ rightarrow e \ rightarrow d \ rightarrow c $

या, $ a \ rightarrow d \ rightarrow b \ rightarrow e \ rightarrow c $

या, $ a \ rightarrow e \ rightarrow b \ rightarrow d \ rightarrow c $

या, $ a \ rightarrow b \ rightarrow e \ rightarrow d \ rightarrow c $

या, $ a \ rightarrow d \ rightarrow e \ rightarrow b \ rightarrow c $

Application of BFS

  • सबसे छोटा रास्ता खोजना
  • अन-वेटेड ग्राफ के लिए न्यूनतम फैले पेड़
  • जीपीएस नेविगेशन प्रणाली
  • एक अप्रत्यक्ष ग्राफ में चक्रों का पता लगाना
  • एक जुड़े घटक के भीतर सभी नोड्स का पता लगाना

Complexity Analysis

$ G (V, E) $ का ग्राफ $ | V | $ कोने की संख्या और $ | E | $ किनारों की संख्या है। यदि चौड़ाई पहले खोज एल्गोरिथ्म ग्राफ़ में प्रत्येक शीर्ष पर जाती है और हर किनारे की जांच करती है, तो इसकी समय जटिलता होगी -

$$ O (| V | + | E |) | ओ (| ई |) $ $

यह $ O (1) $ और $ O (| V2 |) $ के बीच भिन्न हो सकता है

गहराई पहली खोज

गहराई पहली खोज (DFS) एल्गोरिथ्म एक शीर्ष $ v $ से शुरू होती है, फिर यह इसके निकटवर्ती शीर्ष (x) का पता लगाती है जिसे पहले नहीं देखा गया है और "विज़िट" के रूप में चिह्नित किया गया है और $ x $ के निकटवर्ती शीर्ष पर जाता है और जल्द ही।

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

DFS Algorithm

अवधारणा यह है कि पड़ोसी पड़ोसी के सभी पड़ोसी कोने को दूसरे पड़ोसी कोने में जाने से पहले देखें।

  • "तैयार" के रूप में सभी नोड्स की प्रारंभिक स्थिति

  • एक स्टैक में स्रोत शीर्ष रखें और अपनी स्थिति को "प्रतीक्षा" में बदलें

  • स्टैक खाली होने तक निम्नलिखित दो चरण दोहराएं -

    • स्टैक से शीर्ष शीर्ष को पॉप करें और इसे "देखे गए" के रूप में चिह्नित करें

    • स्टैक के शीर्ष पर हटाए गए शीर्ष के सभी पड़ोसियों को धक्का दें जिनकी स्थिति "रेडी" है। उनकी स्थिति को "प्रतीक्षा" के रूप में चिह्नित करें।

Problem

आइए हम एक ग्राफ लेते हैं (सोर्स वर्टेक्स 'ए') है और ट्रैवर्सल ऑर्डर का पता लगाने के लिए डीएफएस एल्गोरिदम लागू करते हैं।

Solution

  • "तैयार" सभी कोने की प्रारंभिक स्थिति।

  • पुश एक ढेर में और "प्रतीक्षा कर रहा है" करने के लिए अपनी स्थिति को बदलने।

  • पॉप एक और "के रूप में देखे जाने वाले" में चिह्नित करें।

  • पुश एक में "रेडी" राज्य के पड़ोसियों ई, डी और बी ढेर के शीर्ष करने के लिए और उन्हें "के रूप में प्रतीक्षा कर रहा है" निशान।

  • पॉप ढेर से, यह निशान के रूप में "देखे जाने वाले", अपने "तैयार" पड़ोसी धक्का ढेर पर।

  • स्टैक से पॉप सी और इसे "विज़िट" के रूप में चिह्नित करें। इसका कोई "रेडी" पड़ोसी नहीं है।

  • स्टैक से पॉप डी और इसे "विज़िट" के रूप में चिह्नित करें। इसका कोई "रेडी" पड़ोसी नहीं है।

  • स्टैक से पॉप और इसे "देखे गए" के रूप में चिह्नित करें। इसका कोई "रेडी" पड़ोसी नहीं है।

  • ढेर खाली है। इसलिए रोका।

तो ट्रैवर्सल ऑर्डर है -

$ a \ rightarrow b \ rightarrow c \ rightarrow d \ rightarrow e $

ट्रैवर्सल के वैकल्पिक आदेश हैं -

$ a \ rightarrow e \ rightarrow b \ rightarrow c \ rightarrow d $

या, $ a \ rightarrow b \ rightarrow e \ rightarrow c \ rightarrow d $

या, $ a \ rightarrow d \ rightarrow e \ rightarrow b \ rightarrow c $

या, $ a \ rightarrow d \ rightarrow c \ rightarrow e \ rightarrow b $

या, $ a \ rightarrow d \ rightarrow c \ rightarrow b \ rightarrow e $

Complexity Analysis

$ G (V, E) $ का ग्राफ $ | V | $ कोने की संख्या और $ | E | $ किनारों की संख्या है। यदि DFS एल्गोरिदम ग्राफ़ में प्रत्येक शीर्ष पर जाता है और हर किनारे की जाँच करता है, तो समय जटिलता है -

$$ \ circleddash (| V | + | E |) $$

Applications

  • एक ग्राफ में चक्र का पता लगाना
  • टोपोलॉजिकल सॉर्टिंग खोजने के लिए
  • यह जांचने के लिए कि क्या ग्राफ द्विभाजित है
  • जुड़े हुए घटकों को खोजना
  • एक ग्राफ के पुलों का पता लगाना
  • रेखांकन में द्वि-कनेक्टिविटी का पता लगाना
  • नाइट की टूर समस्या का समाधान
  • केवल एक समाधान के साथ पहेलियाँ सुलझाना