小A有一个由n个小写字母组成的字符串s,他希望将s划分为若干个子串,使得每个子串中每个字母至多出现一次。
例如,对于字符串street来说,str+e+e+t是满足条件的划分;而s+tree+t不是,因为子串tree中e出现了两次。
额外地,小A给出了价值a₁,a₂,…,aₙ,表示划分后长度为i的子串价值为aᵢ。小A希望最大化划分后得到的子串价值之和。
你能帮他求出划分后子串价值之和的最大值吗?
一行,一个整数,表示划分后子串价值之和的最大值。
6
street
2 1 7 4 3 3
13
8
blossoms
1 1 2 3 5 8 13 21
8