#define _USE_MATH_DEFINES #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define rep(i,n) for (int i = 0; i < (n); ++i) using namespace atcoder; using namespace std; typedef long long int ll; typedef modint998244353 mint; ll gcd(ll a, ll b) { if (a < b)swap(a, b); if (b == 0)return a; return gcd(b, a % b); } int lcm(int a, int b) { return a * b / gcd(a, b); } /* 解説動画参考 解説ブログ参考 */ int main() { int Q; Q = 1; //cin >> Q; while (Q--) { int g, c, p; cin >> g >> c>>p ; string s; cin >> s; int ans = 0; int G, C, P; sort(s.begin(), s.end()); for (int i = 0; i < s.size(); i++) { char t = s[i]; if (t == 'C') { if (g) { g--; ans += 3; } else if (c) { c--; ans++; } else p--; } if (t == 'G') { if (p) { p--; ans += 3; } else if (g) { g--; ans++; } else c--; } if (t == 'P') { if (c) { c--; ans += 3; } else if (p) { p--; ans++; } else g--; } } cout << ans; } return 0; }