কম্পিউটার

হ্যামিলটোনিয়ান সাইকেল


একটি অনির্দেশিত গ্রাফে, হ্যামিলটোনিয়ান পাথ হল একটি পথ, যেটি প্রতিটি শীর্ষবিন্দুকে ঠিক একবার পরিদর্শন করে এবং হ্যামিলটোনিয়ান চক্র বা সার্কিট হল একটি হ্যামিলটোনিয়ান পাথ, যেখানে শেষ শীর্ষবিন্দু থেকে একটি প্রান্ত রয়েছে প্রথম শীর্ষে।

এই সমস্যায়, আমরা একটি গ্রাফে হ্যামিলটোনিয়ান চক্র আছে কিনা তা নির্ধারণ করার চেষ্টা করব। এবং যখন একটি হ্যামিলটোনিয়ান চক্র উপস্থিত থাকে, তখন চক্রটিও মুদ্রণ করুন।

ইনপুট এবং আউটপুট

Input:
The adjacency matrix of a graph G(V, E).
হ্যামিলটোনিয়ান সাইকেল 
Output:
The algorithm finds the Hamiltonian path of the given graph. For this case it is (0, 1, 2, 4, 3, 0). This graph has some other Hamiltonian paths.
If one graph has no Hamiltonian path, the algorithm should return false.

অ্যালগরিদম

এটি বৈধ(v, k)

ইনপুট - শীর্ষবিন্দু v এবং অবস্থান k.

আউটপুট - k অবস্থানে v স্থাপন করা বৈধ কি না তা পরীক্ষা করে।

Begin
   if there is no edge between node(k-1) to v, then
      return false
   if v is already taken, then
      return false
   return true; //otherwise it is valid
End

সাইকেলফাউন্ড(নোড কে)

ইনপুট - গ্রাফের নোড।

আউটপুট - হ্যামিলটোনিয়ান সাইকেল থাকলে সত্য, অন্যথায় মিথ্যা।

Begin
   if all nodes are included, then
      if there is an edge between nodes k and 0, then
         return true
      else
         return false;

   for all vertex v except starting point, do
      if isValid(v, k), then //when v is a valid edge
         add v into the path
         if cycleFound(k+1) is true, then
            return true
         otherwise remove v from the path
   done
   return false
End

উদাহরণ

#include<iostream>
#define NODE 5
using namespace std;

int graph[NODE][NODE] = {
   {0, 1, 0, 1, 0},
   {1, 0, 1, 1, 1},
   {0, 1, 0, 0, 1},
   {1, 1, 0, 0, 1},
   {0, 1, 1, 1, 0},
};
   
/* int graph[NODE][NODE] = {
   {0, 1, 0, 1, 0},
   {1, 0, 1, 1, 1},
   {0, 1, 0, 0, 1},
   {1, 1, 0, 0, 0},
   {0, 1, 1, 0, 0},
}; */

int path[NODE];

void displayCycle() {
   cout<<"Cycle: ";

   for (int i = 0; i < NODE; i++)
      cout << path[i] << " ";
   cout << path[0] << endl;      //print the first vertex again
}

bool isValid(int v, int k) {
   if (graph [path[k-1]][v] == 0)   //if there is no edge
      return false;

   for (int i = 0; i < k; i++)   //if vertex is already taken, skip that
      if (path[i] == v)
         return false;
   return true;
}

bool cycleFound(int k) {
   if (k == NODE) {             //when all vertices are in the path
      if (graph[path[k-1]][ path[0] ] == 1 )
         return true;
      else
         return false;
   }

   for (int v = 1; v < NODE; v++) {       //for all vertices except starting point
      if (isValid(v,k)) {                //if possible to add v in the path
         path[k] = v;
         if (cycleFound (k+1) == true)
            return true;
         path[k] = -1;               //when k vertex will not in the solution
      }
   }
   return false;
}

bool hamiltonianCycle() {
   for (int i = 0; i < NODE; i++)
      path[i] = -1;
   path[0] = 0; //first vertex as 0

   if ( cycleFound(1) == false ) {
      cout << "Solution does not exist"<<endl;
      return false;
   }

   displayCycle();
   return true;
}

int main() {
   hamiltonianCycle();
}

আউটপুট

Cycle: 0 1 2 4 3 0

  1. সি ল্যাঙ্গুয়েজে প্রোগ্রাম ডেভেলপমেন্ট সাইকেল কি?

  2. পাইথনে ক্ষুদ্রতম চক্রের দৈর্ঘ্য ধরে রাখার লক্ষ্য খুঁজে বের করার প্রোগ্রাম

  3. একটি নির্দেশিত গ্রাফে চক্র সনাক্তকরণের জন্য পাইথন প্রোগ্রাম

  4. সাইকেল সাজানোর জন্য পাইথন প্রোগ্রাম