मान लीजिए, शहरों के बीच n शहर और m सड़कें हैं। एम सड़कें हमें सड़कों की एक श्रृंखला में दी गई हैं जहां सड़कें प्रारूप {ऑर्स, डेस्टिनेशन, वेट} में हैं। अब, हम एक त्रिक (s, t, k) को परिभाषित करते हैं जहाँ s, t, और k शहर हैं। अब हमें शहर s से शहर t तक जाने के लिए आवश्यक न्यूनतम समय की गणना करनी होगी। s से t तक जाने के लिए, केवल 1 से k के भीतर के शहरों का दौरा किया जा सकता है। यदि शहर t, s से अगम्य है, तो हम 0 लौटाते हैं। हमें सभी त्रिक (s, t, k) के लिए न्यूनतम समय की गणना करनी होगी और उनका योग प्रिंट करना होगा।
इसलिए, यदि इनपुट n =4, m =2, किनारों ={{1, 2, 5}, {2, 3, 4}, {3, 4, 3}} जैसा है, तो आउटपुट 63 होगा।
कदम
इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
Define one 2D array dvec initialized with value infinity for initialize i := 0, when i < n, update (increase i by 1), do: dvec[i, i] := 0 for initialize i := 0, when i < m, update (increase i by 1), do: a := first value of (edges[i]) b := second value of (edges[i]) c := third value of (edges[i]) decrease a and b by 1 dvec[a, b] := c res := 0 for initialize k := 0, when k < n, update (increase k by 1), do: for initialize i := 0, when i < n, update (increase i by 1), do: for initialize j := 0, when j < n, update (increase j by 1), do: dvec[i, j] := minimum of (dvec[i, j] and dvec[i, k] + dvec[k, j]) if dvec[i, j] is not equal to infinity, then: res := res + dvec[i, j] print(res)
उदाहरण
आइए बेहतर समझ पाने के लिए निम्नलिखित कार्यान्वयन देखें -
#include <bits/stdc++.h> using namespace std; const int INF = 1e9; void solve(int n, int m, vector<tuple<int, int, int>> edges){ vector<vector<int>> dvec(n, vector<int>(n, INF)); for(int i = 0; i < n; i++) dvec[i][i] = 0; for(int i = 0; i < m; i++) { int a = get<0> (edges[i]); int b = get<1> (edges[i]); int c = get<2> (edges[i]); a--; b--; dvec[a][b] = c; } int res = 0; for(int k = 0; k < n; k++) { for(int i = 0; i < n; i++) { for(int j = 0; j < n; j++) { dvec[i][j] = min(dvec[i][j], dvec[i][k]+dvec[k][j]); if(dvec[i][j] != INF) res += dvec[i][j]; } } } cout << res << endl; } int main() { int n = 4, m = 2; vector<tuple<int, int, int>> edges = {{1, 2, 5}, {2, 3, 4}, {3, 4, 3}}; solve(n, m, edges); return 0; }
इनपुट
4, 2, {{1, 2, 5}, {2, 3, 4}, {3, 4, 3}}
आउटपुट
63