Advertisement
Guest User

Closest Points

a guest
Aug 19th, 2014
270
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.78 KB | None | 0 0
  1. //Bismillahir Rahmanir Rahim
  2. /******Harun Or Rashid******/
  3. /***********Template Starts Here***********/
  4. #include<iostream>
  5. #include<cstdio>
  6. #include<cstring>
  7. #include<cmath>
  8. #include<cctype>
  9. #include<cstdlib>
  10. #include<string>
  11. #include<vector>
  12. #include<set>
  13. #include<stack>
  14. #include<queue>
  15. #include<map>
  16. #include<algorithm>
  17. using namespace std;
  18.  
  19. #define MEM(a,b) memset(a,b,sizeof(a))
  20. #define CLR(a) memset(a,0,sizeof(a))
  21. #define MAX(a,b) ((a)>(b)?(a):(b))
  22. #define MIN(a,b) ((a)>(b)?(b):(a))
  23. #define ABS(a) ((a)>0? (a):(-(a)))
  24. #define SQ(a) ((a)*(a))
  25. #define SZ(a) (int)a.size()
  26. #define FORN(i,n) for(i=1;i<=n;i++)
  27. #define FORAB(i,a,b) for(i=a;i<=b;i++)
  28. #define ALL(V) V.begin(),V.end()
  29. #define pb(a) push_back(a)
  30. #define pr(a) cout<<a<<endl
  31. #define pf printf
  32. #define sf scanf
  33. #define swap(a,b) (a ^= b, b ^= a, a ^= b)
  34. #define PI acos(-1)
  35. #define x first
  36. #define y second
  37. #define eps 1e-7
  38.  
  39. typedef int D;
  40. typedef long long int LLD;
  41. typedef unsigned long long int LLU;
  42. typedef vector<D> VI;
  43. typedef set<D> SI;
  44. typedef vector<D>::iterator Viti;
  45.  
  46. /***********Template Ends Here***********/
  47.  
  48. int main()
  49. {
  50.     int N,Q,i;
  51.     LLU mx,pos,tm;
  52.     cin>>N;
  53.     int center[N][3];
  54.     for(i=0; i<N; i++)
  55.         cin>>center[i][0]>>center[i][1]>>center[i][2];
  56.     cin>>Q;
  57.     int bank[Q][3];
  58.     for(i=0; i<Q; i++)
  59.         cin>>bank[i][0]>>bank[i][1]>>bank[i][2];
  60.     mx=pow(bank[0][0]-center[0][0],2)+pow(bank[0][1]-center[0][1],2)+pow(bank[0][2]-center[0][2],2);
  61.     pos=0;
  62.     for(i=1; i<N; i++)
  63.     {
  64.         tm=pow(bank[0][0]-center[i][0],2)+pow(bank[0][1]-center[i][1],2)+pow(bank[0][2]-center[i][2],2);
  65.         if(tm<mx)
  66.         {
  67.             mx=tm;
  68.             pos=i;
  69.         }
  70.     }
  71.     for(i=0; i<Q; i++)
  72.         cout<<pos<<endl;
  73.     return 0;
  74. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement