एक विक्रेता एक शहर में है, उसे अन्य सभी शहरों का दौरा करना है जो सूचीबद्ध हैं, एक शहर से दूसरे शहर की यात्रा की लागत भी प्रदान की जाती है। एक बार सभी शहरों की यात्रा करने और अपने शुरुआती शहर में वापस जाने के लिए उस मार्ग का पता लगाएं जहां लागत न्यूनतम है।
इस मामले के लिए ग्राफ पूरा होना चाहिए, ताकि विक्रेता किसी भी शहर से सीधे किसी भी शहर में जा सके।
यहां हमें न्यूनतम भारित हैमिल्टनियन साइकिल का पता लगाना है।
इनपुट और आउटपुट
Input: Cost matrix of the matrix. 0 20 42 25 30 20 0 30 34 15 42 30 0 10 10 25 34 10 0 25 30 15 10 25 0 Output: Distance of Travelling Salesman: 80
एल्गोरिदम
travellingSalesman (mask, pos)
एक टेबल डीपी है, और सभी नोड्स को चिह्नित करने के लिए VISIT_ALL मान देखे गए हैं
इनपुट - कुछ शहरों, स्थिति को छिपाने के लिए मुखौटा मूल्य।
आउटपुट घटा; सभी शहरों में जाने के लिए सबसे छोटा रास्ता खोजें।
Begin if mask = VISIT_ALL, then //when all cities are visited return cost[pos, 0] if dp[mask, pos] ≠ -1, then return dp[mask, pos] finalCost := ∞ for all cities i, do tempMask := (shift 1 left side i times) if mask AND tempMask = 0, then tempCpst := cost[pos, i] + travellingSalesman(mask OR tempMask, i) finalCost := minimum of finalCost and tempCost done dp[mask, pos] = finalCost return finalCost End
उदाहरण
#include<iostream> #define CITY 5 #define INF 9999 using namespace std; int cost[CITY][CITY] = { {0, 20, 42, 25, 30}, {20, 0, 30, 34, 15}, {42, 30, 0, 10, 10}, {25, 34, 10, 0, 25}, {30, 15, 10, 25, 0} }; int VISIT_ALL = (1 << CITY) - 1; int dp[16][4]; //make array of size (2^n, n) int travellingSalesman(int mask, int pos) { if(mask == VISIT_ALL) //when all cities are marked as visited return cost[pos][0]; //from current city to origin if(dp[mask][pos] != -1) //when it is considered return dp[mask][pos]; int finalCost = INF; for(int i = 0; i<CITY; i++) { if((mask & (1 << i)) == 0) { //if the ith bit of the result is 0, then it is unvisited int tempCost = cost[pos][i] + travellingSalesman(mask | (1 << i), i); //as ith city is visited finalCost = min(finalCost, tempCost); } } return dp[mask][pos] = finalCost; } int main() { int row = (1 << CITY), col = CITY; for(int i = 0; i<row; i++) for(int j = 0; j<col; j++) dp[i][j] = -1; //initialize dp array to -1 cout << "Distance of Travelling Salesman: "; cout <<travellingSalesman(1, 0); //initially mask is 0001, as 0th city already visited }
आउटपुट
Distance of Travelling Salesman: 80