Advertisement
add1ctus

Месечина

Feb 14th, 2015
215
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.50 KB | None | 0 0
  1. #include <iostream>
  2. #include <cmath>
  3.  
  4. using namespace std;
  5.  
  6. double dalecina(int x1, int y1, int x2, int y2)
  7. {
  8.     return sqrt( (x1-x2)*(x1-x2) + (y1-y2)*(y1-y2) );
  9. }
  10.  
  11. int main()
  12. {
  13.     int n;
  14.     cin>>n;
  15.  
  16.     int koordinati[n][2];
  17.     for(int j=0;j<n;j++)
  18.         cin>>koordinati[j][0]>>koordinati[j][1];
  19.  
  20.     double matrica[n][n];
  21.     for(int j=0;j<n;j++)
  22.         for(int k=0;k<n;k++)
  23.         {
  24.             matrica[j][k]=matrica[k][j]=dalecina(koordinati[j][0],koordinati[j][1],koordinati[k][0],koordinati[k][1]);
  25.             if(matrica[j][k]>10)
  26.             {
  27.                 matrica[j][k]=matrica[k][j]=-1;
  28.             }
  29.         }
  30.  
  31.     double dist[n];
  32.     bool visited[n];
  33.  
  34.     for(int j=0;j<n;j++)
  35.     {
  36.         dist[j]=99999999;
  37.         visited[j]=false;
  38.     }
  39.  
  40.     dist[0]=0;
  41.     visited[0]=true;
  42.  
  43.  
  44.     for(int j=0;j<n;j++)
  45.     {
  46.         if(matrica[0][j]!=-1)
  47.             dist[j]=matrica[0][j];
  48.     }
  49.  
  50.     while(!visited[n-1])
  51.     {
  52.         int najbliskoTeme;
  53.         double najkratokPat=999999;
  54.  
  55.         for(int j=0;j<n;j++)
  56.             if(!visited[j] && dist[j]<najkratokPat)
  57.             {
  58.                 najbliskoTeme=j;
  59.                 najkratokPat=dist[j];
  60.             }
  61.  
  62.         visited[najbliskoTeme]=true;
  63.  
  64.         for(int j=0;j<n;j++)
  65.             if(matrica[najbliskoTeme][j]!=-1 && matrica[najbliskoTeme][j]+dist[najbliskoTeme]<dist[j])
  66.                 dist[j]=matrica[najbliskoTeme][j]+dist[najbliskoTeme];
  67.     }
  68.  
  69.     cout<<dist[n-1];
  70.     return 0;
  71. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement