题目传送门
思路
这是一道入门dp题,看到题目要求是求出最多的分值,那大抵是贪心或dp。
但根据经验,dp更简单,且贪心很可能假。
因此,可得:
设 为前 个的最多分值, 为 时代表选择第 个, 为 时则不选第 个。
那么:
Code
using namespace std;
long long n, a[100005], ans = 0;
long long dp[100005][2] = {0};
string s;
int main()
{
ios::sync_with_stdio(0);
cin.tie(0), cout.tie(0);
cin >> n;
for (int i = 1; i <= n; i++) cin >> a[i];
cin >> s;
for (int i = 2; i <= n; i++)
{
if (s[i - 2] != s[i - 1]) dp[i][1] = dp[i - 1][0] + a[i] + a[i - 1];
dp[i][0] = max(dp[i - 1][1], dp[i - 1][0]);
}
cout << max(dp[n][0], dp[n][1]) << endl;
return 0;
}