【题目链接】

点击打开链接

【算法】

正反两遍EXKMP,即可

【代码】

#include<bits/stdc++.h>
using namespace std;
#define MAXC 26
#define MAXL 500010 int T,ans,tmp,i,len;
int a[MAXC+],Next[MAXL],extend1[MAXL],extend2[MAXL],sum[MAXL];
char s1[MAXL],s2[MAXL]; template <typename T> inline void read(T &x) {
int f = ; x = ;
char c = getchar();
for (; !isdigit(c); c = getchar()) { if (c == '-') f = -f; }
for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
x *= f;
}
template <typename T> inline void write(T x) {
if (x < ) { putchar('-'); x = -x; }
if (x > ) write(x/);
putchar(x%+'');
}
template <typename T> inline void writeln(T x) {
write(x);
puts("");
}
inline void exkmp(char *s1,char *s2,int *Next,int *Extend) {
int i=,j,pos;
while (i + < len && s2[i+] == s2[i]) i++;
Next[] = i;
pos = ;
for (i = ; i < len; i++) {
if (i + Next[i-pos] < pos + Next[pos]) Next[i] = Next[i-pos];
else {
j = pos + Next[i-pos] - i;
if (j < ) j = ;
while (i + j < len && s2[j] == s2[i+j]) j++;
Next[i] = j;
pos = i;
}
}
i = ;
while (i < len && s1[i] == s2[i]) i++;
Extend[] = i;
pos = ;
for (i = ; i < len; i++) {
if (i + Next[i-pos] < pos + Extend[pos]) Extend[i] = Next[i-pos];
else {
j = pos + Extend[pos] - i;
if (j < ) j = ;
while (i + j < len && s1[i+j] == s2[j]) j++;
Extend[i] = j;
pos = i;
}
}
} int main() { read(T);
while (T--) {
for (i = ; i <= MAXC; i++) read(a[i]);
scanf("%s",s1);
len = strlen(s1);
sum[] = a[s1[]-'a'+];
for (i = ; i < len; i++) {
s2[len-i-] = s1[i];
if (i > ) sum[i] = sum[i-] + a[s1[i]-'a'+];
}
exkmp(s2,s1,Next,extend1);
exkmp(s1,s2,Next,extend2);
ans = ;
for (i = ; i < len - ; i++) {
tmp = ;
if (extend1[len-i-] == i + ) tmp += sum[i];
if (extend2[i+] == len - i - ) tmp += sum[len-] - sum[i];
ans = max(ans,tmp);
}
writeln(ans);
} return ; }

最新文章

  1. JAVA调用R
  2. Firemonkey 图片显示拉伸不变形
  3. Microsoft.Owin.Hosting 实现启动webapp.dll
  4. 可复用View的PagerAdapter
  5. 2009年到2013年甲子园ED
  6. ecshop销售排行调用促销价格和市场价格
  7. Scrum Meeting---Eleven(2015-11-6)
  8. Java基础知识强化之IO流笔记12:递归之递归解决问题的思想(图解)
  9. linux kernel中timer的使用
  10. Android开源项目分享
  11. OMCS开发手册(02) -- 多媒体连接器
  12. 网站SEO优化问答精选
  13. Linux静默安装matlab
  14. 精选Spring Boot三十五道必知必会知识点
  15. 【命令】MongoDB常用命令记录
  16. 使用AutoMapper实现Dto和Model的自由转换(中)
  17. 使用python(command line)出现的ImportError: No module named &#39;xxx&#39;问题
  18. JS获取节点属性个数及值得方法
  19. Hive HQL基本操作
  20. layoutSubviews什么时候触发调用

热门文章

  1. 解密优秀博士成长史 ——微软亚洲研究院首届博士生学术论坛Panel讨论经验总结
  2. SolidEdge 工程图中如何显示彩色工程图
  3. Ghost本地安装highlight.js使代码高亮
  4. 这样看ACM是不是更好?
  5. FastDFS的配置、部署与API使用解读(1)Get Started with FastDFS(转)
  6. tabhost实现android菜单切换
  7. 李洪强iOS开发之-修改状态栏的字体的颜色
  8. C++类使用static小例子(新手学习C++)
  9. android-測试so动态库(九)
  10. SKStoreReviewController之程序内评价