#include using namespace std; using ll = long long; // #define int ll using PII = pair; #define FOR(i, a, n) for (ll i = (ll)a; i < (ll)n; ++i) #define REP(i, n) FOR(i, 0, n) #define ALL(x) x.begin(), x.end() template T &chmin(T &a, const T &b) { return a = min(a, b); } template T &chmax(T &a, const T &b) { return a = max(a, b); } template bool IN(T a, T b, T x) { return a<=x&&x T ceil(T a, T b) { return a/b + !!(a%b); } template vector make_v(size_t a) { return vector(a); } template auto make_v(size_t a,Ts... ts) { return vector(ts...))>(a,make_v(ts...)); } template typename enable_if::value==0>::type fill_v(T &t, const V &v) { t=v; } template typename enable_if::value!=0>::type fill_v(T &t, const V &v ) { for(auto &e:t) fill_v(e,v); } template ostream &operator <<(ostream& out,const pair& a) { out<<'('< ostream &operator <<(ostream& out,const vector& a){ out<<'['; for(const T &i: a) out< ostream &operator <<(ostream& out, const set& a) { out<<'{'; for(const T &i: a) out< ostream &operator <<(ostream& out, const map& a) { out<<'{'; for(auto &i: a) out<> x >> y >> z; char sc, gc; ll s, g; cin >> sc >> s >> gc >> g; if(sc == gc) { ll n; if(gc=='A') n = x; else if(gc=='B') n = y; else if(gc=='C') n = z; ll ret = abs(s-g); if(gc!='A') chmin(ret, s + n-g + x); if(gc!='B') chmin(ret, s + n-g + y); if(gc!='C') chmin(ret, s + n-g + z); if(gc!='A') chmin(ret, g + n-s + x); if(gc!='B') chmin(ret, g + n-s + y); if(gc!='C') chmin(ret, g + n-s + z); cout << ret << endl; } else { ll n; if(sc=='A') n = x; else if(sc=='B') n = y; else if(sc=='C') n = z; ll m; if(gc=='A') m = x; else if(gc=='B') m = y; else if(gc=='C') m = z; ll l; if(sc!='A' && gc!='A') l = x; if(sc!='B' && gc!='B') l = y; if(sc!='C' && gc!='C') l = z; ll ret = s + g - 1; chmin(ret, s + l + m-g); chmin(ret, n-s + m-g + 1); chmin(ret, n-s + l + g); cout << ret << endl; } return 0; }