大意:把一个字符串分成两串,假如一个字符串是回文串就可以加上它的VALUE,否则它的VALUE为0;

KMP的特点是可以求出前缀与后面的字符串是否匹配,

注意回文串的特点,所以当我们把回文串反转的时候会发现与前面的字符串匹配,

然后将字符串整个反转可以求出后缀的,

利用其特点可以快速判断回文串,

CODE;

#include<cstdio>
#include<cmath>
#include<algorithm>
#include<string.h>
#define N 500008
using namespace std;
typedef long long ll; char s[*N];
int next[*N];
int a[];
int sum[N*],pos[*N],pre[*N]; void get_next(char *s)//NEXT数组
{
next[]=-;
int k=-,i=;
int l=strlen(s);
while (i<l)
{
if (k==-||s[i]==s[k])
{
k++;i++;
next[i]=k;
}
else k=next[k];
}
} int main()
{
int cas;
scanf("%d",&cas); while (cas--)
{
memset(pos,,sizeof(pos));
memset(pre,,sizeof(pre));
for (int i=;i<;i++) scanf("%d",&a[i]);
scanf("%s",s); int len=strlen(s);
for (int i=;i<=len;i++) sum[i]=sum[i-]+a[s[i-]-'a'];//预先处理SUM数组,注意我们把A[I]的值移位了。
s[len]='#';
int k=len,l=len;
while (k) s[++l]=s[--k];//字符串反接在后面
s[++l]='\0';
get_next(s);
int dol=l;
while (next[dol]) {pre[next[dol]]=len+;dol=next[dol];}
for (int i=;i<len;i++)
swap(s[i],s[len++i]); get_next(s);
dol=l;
while (next[dol]) {pos[next[dol]]=len+;dol=next[dol];}; int ans=-;
for (int i=;i<len;i++)//核心代码,计算值
{
int ss=;
if (pre[i]==len+) ss+=sum[i];
if (pos[len-i]==len+) ss+=sum[len]-sum[i];
ans=max(ans,ss);
}
printf("%d\n",ans); }
return ;
}

KMP_Best Reward的更多相关文章

  1. ACM: hdu 2647 Reward -拓扑排序

    hdu 2647 Reward Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Des ...

  2. 扩展KMP --- HDU 3613 Best Reward

    Best Reward Problem's Link:   http://acm.hdu.edu.cn/showproblem.php?pid=3613 Mean: 给你一个字符串,每个字符都有一个权 ...

  3. 回文串---Best Reward

    HDU   3613 Description After an uphill battle, General Li won a great victory. Now the head of state ...

  4. hdu 2647 Reward

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2647 Reward Description Dandelion's uncle is a boss o ...

  5. Reward

    Reward Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  6. hdoj 2647 Reward【反向拓扑排序】

    Reward Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  7. Reward HDU

    Reward                                    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32 ...

  8. Reward(拓扑结构+邻接表+队列)

    Reward Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submis ...

  9. HDU 3613 Best Reward 正反两次扩展KMP

    题目来源:HDU 3613 Best Reward 题意:每一个字母相应一个权值 将给你的字符串分成两部分 假设一部分是回文 这部分的值就是每一个字母的权值之和 求一种分法使得2部分的和最大 思路:考 ...

随机推荐

  1. Java 数组操作

    参考了网上别人的代码,在Java中对数组的比较便利的操作是 将数组转换成集合再利用集合所提供的add remove等方法进行增删,然后再转换成原数组类型 如 String[] --> 填充至 A ...

  2. STM32F0xx_PWR低功耗配置详细过程

    Ⅰ.概述 今天总结PWR部分知识,请看“STM32F0x128参考手册V8”第六章.提供的软件工程是关于电源管理中的停机模式,工程比较常见,但也是比较简单的一个实例,根据项目的不同还需要适当修改或者添 ...

  3. [terry笔记]Oracle数据泵-schema导入导出

    数据泵是10g推出的功能,个人倒数据比较喜欢用数据泵. 其导入的时候利用remap参数很方便转换表空间以及schema,并且可以忽略服务端与客户端字符集问题(exp/imp需要排查字符集). 数据泵也 ...

  4. 【javascript】随手记代码

    //js实现的当前界面的刷新.前进.后退 <input type="button" value="刷新" onclick="window.loc ...

  5. 菜鸟学习Hibernate——配置Hibernate环境

    一.概念. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库.既然学习Hibernate那么第 ...

  6. Base

    base 关键字用于从派生类中访问基类的成员: 调用基类上已被其他方法重写的方法. 指定创建派生类实例时应调用的基类构造函数. 基类访问只能在构造函数.实例方法或实例属性访问器中进行. 从静态方法中使 ...

  7. hdu 1023 Train Problem II

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1212 Train Problem II Description As we all know the ...

  8. 打造一款属于自己的web服务器——开篇

    JVM总结慢慢来吧,先插播一篇水文,来介绍下最近业余一直在写的一个小项目——easy-httpserver(github).适合新手学习,大神们路过即可^_^. 一.这是个什么玩意? easy-htt ...

  9. jsapi支付,提示redirect_uri 参数错误

    检查授权目录(微信支付——配置中心) appid MCHID KEYS 配置参数是否正确 appsecrect 配置是否正确(开发者中心) 如果是使用测试链接,需要同时指定测试授权目录,测试账号,并且 ...

  10. (转)redis 学习笔记(1)-编译、启动、停止

    redis 学习笔记(1)-编译.启动.停止   一.下载.编译 redis是以源码方式发行的,先下载源码,然后在linux下编译 1.1 http://www.redis.io/download 先 ...