【GDKOI 2021提高组DAY2】抄写
时间:2021-08-11
本文章向大家介绍【GDKOI 2021提高组DAY2】抄写,主要包括【GDKOI 2021提高组DAY2】抄写使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
\(\text{Solution}\)
\(dp\) 翻折就只需预处理回文中心
\(Manacher\) 预处理即可
\(Code\)
#include<cstdio>
#include<iostream>
#define LL long long
using namespace std;
const int N = 1e6 + 5;
int n, p[N << 1];
LL f[N << 1], cost[30], C;
char s[N], str[N << 1];
inline void Manacher()
{
int len = n;
str[0] = '@', str[1] = '#', n = 2;
for(register int i = 1; i <= len; i++) str[n++] = s[i], str[n++] = '#';
str[n] = '$';
for(register int i = 1, mx = 0, id = 0; i <= n; i++)
{
p[i] = (i < mx ? min(p[id * 2 - i], mx - i) : 1);
while (str[i + p[i]] == str[i - p[i]]) ++p[i];
if (i + p[i] > mx) mx = i + p[i], id = i;
}
}
LL INF = 0x3f3f3f3f3f3f3f3f;
LL tag[N << 3];
#define ls (p << 1)
#define rs (ls | 1)
#define mid ((l + r) >> 1)
void build(int p, int l, int r)
{
tag[p] = INF;
if (l == r) return;
build(ls, l, mid), build(rs, mid + 1, r);
}
void update(int p, int l, int r, int x, int y, LL v)
{
if (x <= l && r <= y) return void(tag[p] = min(tag[p], v));
if (x <= mid) update(ls, l, mid, x, y, v);
if (y > mid) update(rs, mid + 1, r, x, y, v);
}
LL query(int p, int l, int r, int x)
{
LL ret = tag[p];
if (l == r) return ret;
if (x <= mid) ret = min(ret, query(ls, l, mid, x));
else ret = min(ret, query(rs, mid + 1, r, x));
return ret;
}
int main()
{
freopen("copy.in", "r", stdin);
freopen("copy.out", "w", stdout);
scanf("%d%lld", &n, &C);
for(register int i = 0; i < 26; i++) scanf("%lld", &cost[i]);
scanf("%s", s + 1), Manacher();
build(1, 1, n);
for(register int i = 1; i <= n; i++)
{
if (str[i] == '#' || str[i] == '$') f[i] = f[i - 1];
else f[i] = f[i - 1] + cost[str[i] - 'a'];
f[i] = min(f[i], query(1, 1, n, i) + C);
update(1, 1, n, i + 1, min(i + p[i] - 1, n), f[i]);
}
printf("%lld\n", f[n]);
}
原文地址:https://www.cnblogs.com/leiyuanze/p/15127399.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 微信网页扫码登录和公众号网页授权登录的比较
- 【TBase开源版测评】分布式数据库复制表关联查询
- v-decorator的取值与赋值
- fastjson导致spring security oauth2的token序列化错误
- 微信小程序webview,a锚点跳转,回退时一直保留在原页面
- SLURM使用教程
- MIME 类型大全,你值得收藏
- Jetbrains系列---PyCharm, Goland翻译插件推荐Translation
- 熬夜总结了 “HTML5画布” 的知识点(共10条)
- 在PyTorch中使用深度自编码器实现图像重建
- Django+Vue开发生鲜电商平台之9.个人中心功能开发
- Serverless 实战:通过 Component 实现多地域部署容灾
- SQL 行转列+窗口函数的实例
- 回答一下这 10 个最常见的 Javascript 问题
- 千万级数据表选错索引导致的线上慢查询事故