Advertisement
apl-mhd

online

May 6th, 2018
167
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.74 KB | None | 0 0
  1. #include <iostream>
  2. #include <cstdio>
  3. #include <stack>
  4. #include <queue>
  5. #include <algorithm>
  6. #include <vector>
  7. #define MAX_SZ 100
  8. #include <climits>
  9. #include <utility>
  10.  
  11.  
  12. using namespace std;
  13.  
  14. /*
  15. 5 10
  16. 0 1 10
  17. 0 3 5
  18. 1 2 1
  19. 1 3 2
  20. 2 4 4
  21. 3 1 3
  22. 3 2 9
  23. 3 4 2
  24. 4 0 7
  25. 4 2 6
  26. */
  27.  
  28. int n,m;
  29. vector< vector< pair<int, int> > >adj;
  30.  
  31.  
  32. //priority_queue< pair<int , int >,  vector< pair<int, int> >,  greater<pair<int ,int >>   > q;
  33. priority_queue<pair<int,int>, vector<pair<int,int>>, greater<pair<int,int>>>q;
  34.  
  35.  
  36.  
  37. void print_graph(){
  38.  
  39.     printf("|V| : %d  |E| : %d \n", n, m);
  40.  
  41.     for(int i=0; i<n; i++){
  42.  
  43.         printf("%d -> ",i);
  44.  
  45.         for(int j=0; j < adj[i].size(); j++){
  46.  
  47.             printf("%d, %d ", adj[i][j].first, adj[i][j].second);
  48.         }
  49.  
  50.         printf("\n");
  51.     }
  52.  
  53. }
  54.  
  55. int dist[MAX_SZ];
  56. int visited[MAX_SZ];
  57. int parent[MAX_SZ];
  58.  
  59.  
  60. void init(int s){
  61.  
  62.     for(int i=0; i< n; i++){
  63.         dist[i] = INT_MAX;
  64.         visited[i] = 0;
  65.         parent[i] = -1;
  66.  
  67.     }
  68.  
  69.     dist[s]=0;
  70.  
  71. }
  72.  
  73. void relax(int u, int v, int w){
  74.  
  75.  
  76.  
  77. }
  78.  
  79. int min_dist_vertex(){
  80.  
  81.     return  0;
  82.  
  83. }
  84.  
  85.  
  86. void dijkstra(int s){
  87.  
  88.     init(s);
  89.     q.push(make_pair(0,0));
  90.  
  91.     while(!q.empty()){
  92.  
  93.         pair<int,int>p;
  94.  
  95.         p = q.top();
  96.         q.pop();
  97.  
  98.         int u = p.second;
  99.         int uwt = p.first;
  100.  
  101.      //   cout<<u<<" ";
  102.  
  103.         visited[u] = 1;
  104.  
  105.  
  106.         for (int i = 0; i < adj[u].size() ; ++i) {
  107.  
  108.             int v =adj[u][i].first;
  109.             int w = adj[u][i].second;
  110.  
  111.  
  112.             int tw = uwt + w;
  113.  
  114.             if(visited[v] == 0 && tw < dist[v]) {
  115.                 dist[v] = tw;
  116.                 q.push(make_pair(tw,v));
  117.  
  118.                 parent[v] = u;
  119.  
  120.             }
  121.  
  122.  
  123.         }
  124.  
  125.     }
  126.  
  127.  
  128. }
  129. /*
  130.  
  131. void printpath(int i){
  132.  
  133.     while( parent[i] !=-1){
  134.  
  135.  
  136.         int back = parent[i];
  137.  
  138.         cout<<back<<" ";
  139.  
  140.         i = parent[i];
  141.  
  142.     }
  143.  
  144.  
  145. }
  146. */
  147.  
  148. void  printpathRecursion(int i){
  149.  
  150.  
  151.     if(parent[i] ==-1)
  152.         return;
  153.  
  154.         printpathRecursion(parent[i]);
  155.  
  156.     cout<<parent[i]<<" ";
  157.  
  158.  
  159. }
  160.  
  161. int main()
  162. {
  163.     adj.resize(MAX_SZ);
  164.     freopen("graph2.txt", "r", stdin);
  165.     scanf("%d%d",&n,&m);
  166.  
  167.  
  168.  
  169.     for(int i=0; i<m; i++){
  170.         int u, v,w;
  171.  
  172.         scanf("%d%d%d",&u,&v,&w);
  173.         adj[u].push_back(make_pair(v,w));
  174.  
  175.     }
  176.  
  177.     print_graph();
  178.  
  179.     dijkstra(0);
  180.  
  181.  
  182.  
  183.    // printpath(2);
  184.  
  185.     cout<<"\n-----printing path-----\n";
  186.  
  187.     cout<<" V : "<<0<<", Path: 0"; printpathRecursion(0);
  188.     cout<<" Cost : "<<dist[0]<<endl;
  189.  
  190.  
  191.     for(int i=1; i<n; i++){
  192.  
  193.        cout<<" V : "<<i<<", Path: ";
  194.         printpathRecursion(i);
  195.         cout<<" "<<i;
  196.         cout<<", Cost : "<<dist[i]<<endl;
  197.  
  198.  
  199.     }
  200.  
  201.  
  202.  
  203.  
  204.     return 0;
  205. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement