Advertisement
Guest User

Untitled

a guest
Feb 22nd, 2019
76
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.08 KB | None | 0 0
  1. #define _CRT_SECURE_NO_WARNINGS
  2.  
  3. #include <iostream>
  4. #include <stdio.h>
  5. #include <vector>
  6. #include <string>
  7. #include <algorithm>
  8. #include <queue>
  9. #include <map>
  10. #include <set>
  11.  
  12. using namespace std;
  13.  
  14. const int INF = 10000000;
  15.  
  16. int main()
  17. {
  18. freopen("input.txt", "r", stdin);
  19. freopen("output.txt", "w", stdout);
  20. int n, ch, m, s, f;
  21. cin >> n >> s >> f;
  22. int dist[10000];
  23. for (int i = 0; i <= 10000; i++) {
  24. dist[i] = INF;
  25. }
  26. vector < vector< pair <int, int> > > v;
  27. dist[s] = 0;
  28. vector <bool> used (n);
  29. for (int i = 0; i < n; i++) {
  30. for (int j = 0; j < n; j++) {
  31. cin >> ch;
  32. v[i].push_back(make_pair(j, ch));
  33. }
  34. }
  35. for (int i = 0; i < n; i++) {
  36. int now = -1;
  37. for (int j = 0; j < n; j++) {
  38. if (!used[j] && (now == -1 || dist[j] < dist[now])) {
  39. now = j;
  40. }
  41. }
  42. if (dist[now] == INF) {
  43. break;
  44. }
  45. used[now] = true;
  46. for (int j = 0; j < v[now].size(); j++) {
  47. int to = v[now][j].first;
  48. int how = v[now][j].second;
  49. if (dist[now] + how < dist[to]) {
  50. dist[to] = dist[now] + how;
  51. }
  52. }
  53. }
  54. cout << dist[f];
  55. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement