Advertisement
Guest User

Untitled

a guest
Mar 30th, 2017
60
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.53 KB | None | 0 0
  1. // Graph_lab2.cpp: определяет точку входа для консольного приложения.
  2. //
  3.  
  4. #include "stdafx.h"
  5. #include <vector>
  6. #include <iostream>
  7. #include <set>
  8. #include <algorithm>
  9. using namespace std;
  10.  
  11. // Деикстра
  12.  
  13. int main()
  14. {
  15.  
  16. int n, m;
  17. int s, f;
  18. freopen("input.txt", "rt", stdin);
  19. freopen("output.txt", "wt", stdout);
  20. cin >> n >> m;
  21. cin >> s >> f;
  22. s -= 1;
  23. f -= 1;
  24. vector < vector < pair<int, int> > > graph(n);
  25. for (int i = 0; i < m; i++) {
  26. int a, b, c;
  27. cin >> a >> b >> c;
  28. graph[a - 1].push_back(make_pair(b - 1, c));
  29. graph[b - 1].push_back(make_pair(a - 1, c));
  30. }
  31.  
  32. vector<int> d(n, INT32_MAX);
  33. vector<int> p(n);
  34. // начальная
  35. d[s] = 0;
  36.  
  37. vector<int> u(n);
  38.  
  39. for (int i = 0; i < n; ++i) {
  40. // индекс минимальной вершины
  41. int v = -1;
  42. for (int j = 0; j < n; ++j) {
  43. if (!u[j] && (v == -1 || d[j] < d[v])) {
  44. v = j;
  45. }
  46. }
  47. if (d[v] == INT32_MAX) {
  48. break;
  49. }
  50. u[v] = true;
  51.  
  52. for (size_t j = 0; j < graph[v].size(); ++j) {
  53. int to = graph[v][j].first;
  54. int len = graph[v][j].second;
  55. if (d[v] + len < d[to]) {
  56. d[to] = d[v] + len;
  57. p[to] = v;
  58. }
  59. }
  60. }
  61. if (!u[f]) {
  62. cout << "-1";
  63. return 0;
  64. }
  65.  
  66. vector<int> path;
  67. for (int v = f; v != s; v = p[v]) {
  68. path.push_back(v);
  69. }
  70. path.push_back(s);
  71. reverse(path.begin(), path.end());
  72.  
  73. cout << d[f] << endl;
  74. for (int i = 0; i < path.size(); i++)
  75. {
  76. cout << path[i] + 1 << " ";
  77. }
  78.  
  79. return 0;
  80. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement