描述
李老师发现了一条由 n 个单元格组成的条带,从左到右编号 1~n。在第 i 个单元格中,有一个正整数 ai 和一个字母 si,其中所有 si 要么是 ‘L’,要么是 ‘R’。
在一次操作中,你可以选择两个索引 l 和 r (1 ≤ l < r ≤ n),使得 s[l] = ‘L’ 且 s[r] = ‘R’,并执行以下操作,将 a[l] + a[l+1] + …… +a[r-1] + a[r] 的分数加到当前得分中,同时你无法再选择这些位置的索引 !!!
例如,对于下面的条带:
image.png
你可以首先选择 l = 1,r = 2,并将 3 + 5 = 8 加到你的得分中
然后选择 l = 3, r = 6,并将 1 + 4 + 3 + 2 加到你的得分中
总得分为 18
李老师邀请你尝试通过执行任意(可能为零)次数的操作来获得尽可能高的分数。
输入描述
第一行包含一个整数 t(1 <= t <= 100) — 测试用例的数量
每个测试用例的第一行包含一个整数 n(2 <= n <= 1e5)— 条带的长度
每个测试用例的第二行包含 n 个整数 ai (2 <= ai <= 1e5)— 写在条带上的数字
每个测试用例的第三行包含一个字符串 s,由 n 个字符 ‘L’ 和 ‘R’ 组成
输出描述
对于每个测试用例,输出一个整数 — 可以获得的最高分数
用例输入 1
4
6
3 5 1 4 3 2
LRLLLR
2
2 8
LR
2
3 9
RL
5
1 2 3 4 5
LRLRR
用例输出 1
18
10
0
22
得开O2
#include <bits/stdc++.h>
#define ll long long//懒惰
using namespace std;
ll s[100030];
char ss[100030];
int main(){
ios::sync_with_stdio(false);
cin.tie(0);//流加速
ll t;
cin>>t;
while(t--){
memset(s,0,sizeof(s));
ll n;
cin>>n;
for(int i=1;i<=n;i++){
cin>>s[i];
s[i]=s[i]+s[i-1];//求前缀和
}
for(int i=1;i<=n;i++){
cin>>ss[i];
}
ll l=1,r=n;
ll sum=0;
while(l<r){
while(l<r&&ss[l]=='R')l++;
while(l<r&&ss[r]=='L')r--;
if(l<r) sum+=s[r]-s[l-1];//加上区间和
l++,r--;//手动推指针
}
cout<<sum<<endl;
}
}
272

被折叠的 条评论
为什么被折叠?



