#include using namespace::std; const int N = 200000 + 5; int n; int a[N]; char s[N]; long long solve(){ long long ans = LLONG_MIN; long long mini = 0; long long prefix = 0; for(int i = 0; i < n; i++){ if(s[i] == 'R') prefix += a[i]; else prefix -= a[i]; ans = max(ans, prefix - mini); mini = min(mini, prefix); } return abs(ans); } int main(){ scanf("%d", &n); scanf("%s", s); for(int i = 0; i < n; i++) scanf("%d", a + i); long long ans1 = solve(); for(int i = 0; i < n; i++){ if(s[i] == 'R') s[i] = 'B'; else s[i] = 'R'; } long long ans2 = solve(); printf("%lld\n", max(ans1, ans2)); return 0; }