5#include<iostream>
6#include<string.h>
7using namespace std;
8int dis[53][53];
9const int INF=10000000;
10void Floyd(int n)
11{
12 for(int k=1; k<=n; k++)
13 for(int i=1; i<=n; i++)
14 for(int j=1; j<=n; j++)
15 if(i!=k&&k!=j&&i!=j&&dis[i][k]+dis[k][j]<dis[i][j])
16 dis[i][j]=dis[i][k]+dis[k][j];
17
18}
19
20
21int main()
22{
23 int p,i,j,k,d,n1,n2;
24 cin>>p;
25 memset(dis,0,sizeof (dis));
26 for(i=1; i<=52; i++)
27 for(j=1; j<=52; j++)
28 dis[i][j]=INF;
29
30 for(i=1; i<=p; i++)
31 {
32 char v1,v2;
33 cin>>v1>>v2>>d;
34 if(v1==v2)continue;
35 n1=(v1>='a'?v1-'a'+1:v1-'A'+26+1);
36 n2=(v2>='a'?v2-'a'+1:v2-'A'+26+1);
37 if(d<dis[n1][n2])dis[n1][n2]=dis[n2][n1]=d;
38 }
39
40 Floyd(52);
41
42 int min=INF+100;
43 char c;
44 for(i=27; i<=51; i++) //大写字母到Z
45 {
46 if(dis[i][52]<min){min=dis[i][52];c=i; }
47 }
48 cout<<char(c-27+'A')<<' '<<min<<endl;
49 //system("pause");
50 return 0;
51}
52