#include #include #include using namespace std; using namespace __gnu_pbds; #define int long long int template using ordered_set = tree, rb_tree_tag, tree_order_statistics_node_update>; #define ld long double #define nl cout << "\n"; #define getunique(v) \ { \ sort(v.begin(), v.end()); \ v.erase(unique(v.begin(), v.end()), v.end()); \ } #define forn(a, b) for (int i = a; i < b; i++) #define __builtin_popcountll __builtin_popcountll #define __builtin_clzll __builtin_clzll #define __builtin_ctzll __builtin_ctzll #define yesno(b) cout << ((b) ? "YES" : "NO"); #define pii pair #define mp(a, b) make_pair(a, b) #define pb push_back #define all(a) a.begin(), a.end() #define vi vector #define hhh cout << "here" << endl; #define mod1 1000000007 #define mod2 998244353 const int inf = 1e17 + 1; #define FL(i, a, n) for (int i = a; i < n; i++) #define FR(i, a, n) for (int i = a; i >= n; i--) void solve() { int n; cin >> n; string s; cin >> s; s = "!" + s; vi ps(n + 1, 0); forn(1, n+1) ps[i] = ps[i - 1] + (s[i] == 'E'); vi a(n + 1); forn(1, n + 1) cin >> a[i]; vi p(n + 1, 0); forn(1, n + 1) p[i] = p[i - 1] + a[i]; int q; cin >> q; while (q--) { int x; cin >> x; int ans = 0; forn(1, n + 1) { if (a[i] > x) continue; int l = i, r = n + 1; while (r > l + 1) { int mid = (l + r) / 2; if (p[mid] - p[i - 1] <= x) { l = mid; } else { r = mid; } } // cout<> t; while (t--) { solve(); // nl; } return 0; }