#include <set>#include <map>#include <queue>#include <stack>#include <math.h>#include <stdio.h>#include <stdlib.h>#include <iostream>#include <limits.h>#include <string.h>#include <string>#include <algorithm>#define MId(x,y) ( ( x + y ) >> 1 )#define L(x) ( x << 1 )#define R(x) ( x << 1 | 1 )#define BUG puts("here!!!")using namespace std;const int MAX = 1010;const double pi = acos(-1.0);const double inf = 1e30;struct point { double lng, lat, x,y;};point p[MAX];const double eps = 1e-6;bool dy(double x,double y){return x > y + eps;}bool xy(double x,double y){return x < y - eps;}bool dyd(double x,double y){ return x > y - eps;}bool xyd(double x,double y){return x < y + eps;} bool dd(double x,double y) {return fabs( x - y ) < eps;} double torad(double x){return x*pi/180;}double angle_3d(double lng1, double lat1, double lng2, double lat2) { return acos(cos(lat1)*cos(lat2)*cos(lng1 - lng2) + sin(lat1)*sin(lat2)); } double dis(int k,int i){double ang = angle_3d(p[i].lng, p[i].lat, p[k].lng, p[k].lat);return ang;}int solve(int n){double mmin = inf;int t;for(int i=0; i<n; i++){double mmax = 0;for(int k=0; k<n; k++){if( k == i ) continue;if( dy(dis(k,i), mmax) )mmax = dis(k,i);}if( xyd(mmax, mmin) ){mmin = mmax;t = i;}}return t;}int main(){int n;double x, y;while( ~scanf("%d", &n) ){for(int i=0; i<n; i++){scanf("%lf %lf", &x, &y);p[i].lat = torad(x);p[i].lng = torad(y);p[i].x = x; p[i].y = y;}int ans = solve(n);printf("%.2lf %.2lfn", p[ans].x, p[ans].y);}return 0;}