#include // #include using namespace std; // using namespace atcoder; typedef long long ll; typedef long double ld; typedef vector vi; typedef vector vll; typedef vector vld; typedef vector vvi; typedef vector vvll; template using Vec = vector; template using Graph = Vec>; #define _overload3(_1,_2,_3,name,...) name #define _rep(i,n) repi(i,0,n) #define repi(i,a,b) for(int i=int(a);iint(b);--i) #define rrep(...) _overload3(__VA_ARGS__,rrepi,_rrep)(__VA_ARGS__) #define all(x) (x).begin(),(x).end() #define SORT(x) sort(all(x)) #define REVERSE(x) reverse(all(x)) templatebool chmax(T &a, const T &b) { if (abool chmin(T &a, const T &b) { if (b> N >> X >> Y; int M = X+Y; rep(i, N) { int p; char c; cin >> p >> c; A[i%M][c-'A'] += p; } vector> B; rep(i, M) B.push_back({A[i][0]-A[i][1], i}); sort(all(B), greater>()); ll ans = 0; for (auto [_, i]: B) { if (X > 0) { ans += A[i][0]; X--; } else { ans += A[i][1]; Y--; } } cout << ans << endl; }