【GDOI2016模拟3.15】基因合成(回文串+性质+DP)
【GDOI2016模拟3.15】基因合成
题意:
- 给一个目标串,要求从空串进行最少的操作次数变成目标串,操作有两种:
- 在串的头或尾加入一个字符.
- 把串复制一遍后反向接到串的末尾.
因为有回文操作,所以可以想到一些与回文有关的东西.
如Manacher,回文树……
这里采用强大的回文树.
首先注意到目标串可以看作是由一个长度为偶数的回文串在首尾加上若干字符得到的一个串.
所以我们可以求出原串中所有的偶回文串,然后再加加减减一下.
但为什么长度为奇数的不用讨论呢?
这是因为长度为奇数的回文串不可能通过第二个操作得到,所以不管如何,它对答案都没有贡献,它只能通过一个字符一个字符的加得到,尽管它的子串里可能有长度为偶数的回文串,但长度为偶数的回文串无论如何不可能通过第二个操作变为长度为奇数的回文串,所以我们依然可视作它是一个字符一个字符加入的.
然后我们继续讨论长度为偶数的回文串.
首先它可以由它的父亲状态得来,也就是在它父亲状态的最少操作数上+1得到.
当然,它也可以由一个不超过其自身长度一般的最长回文后缀进行一些操作后得来.
两者取最小值即为此偶回文串的最少操作数.
这实质上就是个在回文树上DP的东西.
现在问题还存在的是如何找到一个不超过其自身长度一半的偶回文串.
这一点我们可以借鉴回文树求\(fail\)的过程,我们设一个\(trans\)表示类似的东西,只不过多一个限制就是不能超过其长度一半.
然后每次从一个状态的父亲状态的\(trans\)开始找起来.
同样可以势能分析,时间复杂度显然是\(O(n)\)的.
当然,还可以打倍增....不过比较蛋疼。。。
#include <cstdio>
#include <cstring>
#include <iostream>
#define I register int
#define F(i, a, b) for (I i = a; i <= b; i ++)
#define mem(a, b) memset(a, b, sizeof a)
#define mn(a, b) ((a) = (a) < (b) ? (a) : (b))
const int N = 1e5 + 10, M = 26;
using namespace std;
int T; char ch[N];
int cur, lens, las, p, now, ans, len[N], fail[N], son[N][M], f[N], trans[N];
int Node(I x) { len[p] = x; return p ++; }
int getfail(I x) { while (ch[now] ^ ch[now - len[x] - 1]) x = fail[x]; return x; }
void Add(I x) {
cur = getfail(las);
if (!son[cur][x]) {
I t = Node(len[cur] + 2);
fail[t] = son[getfail(fail[cur])][x];
son[cur][x] = t;
}
las = son[cur][x];
if (len[las] & 1)
f[las] = len[las];
else
{
f[las] = f[cur] + 1;
I k = trans[cur];
while (ch[now - len[k] - 1] ^ ch[now] || (len[k] + 2) * 2 > len[las]) k = fail[k];
trans[las] = son[k][x];
mn(f[las], f[trans[las]] + len[las] / 2 - len[trans[las]] + 1);
}
mn(ans, f[las] + lens - len[las]);
}
int main() {
for (scanf("%d", &T); T --; ) {
scanf("%s", ch + 1);
p = 0, lens = strlen(ch + 1);
Node(0), Node(- 1), f[0] = 1;
fail[0] = 1, las = 0, ans = 1e9;
F(i, 1, lens) now = i, Add(ch[i] - 'A');
printf("%d\n", ans);
F(i, 0, p + 2) mem(son[i], 0);
}
}
【GDOI2016模拟3.15】基因合成(回文串+性质+DP)的更多相关文章
- 关于回文串的DP问题
问题1:插入/删除字符使得原字符串变成一个回文串且代价最小 poj 3280 Cheapest Palindrome 题意:给出一个由m中字母组成的长度为n的串,给出m种字母添加和删除花费的代价,求让 ...
- 回文串 --- 动态dp UVA 11584
题目链接: https://cn.vjudge.net/problem/34398/origin 本题的大意其实很简单,就是找回文串,大致的思路如下: 1. 确定一个回文串,这里用到了自定义的chec ...
- poj3280 Cheapest Palindrome(回文串区间dp)
https://vjudge.net/problem/POJ-3280 猛刷简单dp第一天第三题. 这个据说是[求字符串通过增减操作变成回文串的最小改动次数]的变体. 首先增减操作的实质是一样的,所以 ...
- 1154 回文串划分(DP+Manacher)
1154 回文串划分 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 有一个字符串S,求S最少可以被划分为多少个回文串. 例如:abbaabaa,有多种划分方式. ...
- uva 10453 【回文串区间dp】
Uva 10453 题意:给定字符串,问最少插入多少个字符使其变成回文串,并任意输出一种结果. 题解:和Uva 10739类似,这里是只能增加.类似定义dp[i][j]表示子串Si...Sj变为回文串 ...
- [LeetCode] Palindrome Partitioning 拆分回文串
Given a string s, partition s such that every substring of the partition is a palindrome. Return all ...
- 【Manacher算法】最长子回文串
[Manacher算法] 这个算法用来找出一个字符串中最长的回文子字符串. 如果采取暴力解最长回文子字符串问题,大概可以有两种思路:1. 遍历出所有子字符串找其中最长的回文 2. 从每个字符作为中心, ...
- 计蒜之道 初赛 第三场 题解 Manacher o(n)求最长公共回文串 线段树
腾讯手机地图 腾讯手机地图的定位功能用到了用户手机的多种信号,这当中有的信号的作用范围近.有的信号作用的范围则远一些.有的信号相对于用户在不同的方位强度是不同的,有的则是在不论什么一个方向上信号强度都 ...
- 马拉车,O(n)求回文串
马拉车,O(n)求回文串 对整个马拉车算法步骤做个总结: 第一步:将每个原字母用两个特殊字符包围如: aaa --> #a#a#a# abab -->#a#b#a#b 同时可以由这个翻倍的 ...
随机推荐
- 通过Xtrabackup实现MySQL实例的全库备份与按需单库恢复
在实际的生产环境中,为了管理方便,我们一般是通过 Xtrabackup实现实例的全库备份,即将实例上的所有数据库备份. 但是,考虑到快速恢复 我们常常面临的需求是快速还原单个数据库.针对初学者来说,网 ...
- Kafka相关内容总结(存储和性能)
Kafka消息的存储 Kafka的设计基于一种非常简单的指导思想:不是要在内存中保存尽可能多的数据,在需要时将这些数据刷新(flush)到文件系统,而是要做完全相反的事情.所有数据都要立即写入文件系统 ...
- EOS开发实战
EOS开发实战 在上一篇文章<EOS开发入门>中,我们为大家介绍了EOS的节点启动和合约部署和调用等入门知识.本次我们来实现一个复杂的例子,可以为其取一个高大上的名字-悬赏任务管理系统 ...
- 事务的ACID属性,图解并发事务带来问题以及事务的隔离级别
事务的概述 事务是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行. 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源.通过将一组相关操作组 ...
- HTML---标签的分类 | display | visibility
一.HTML标签的分类和转换 1.1,三类HTML标签 1.2,三类HTML标签的特点 1.3,三类标签的转换--display:none隐藏于visibility不同之处 二.HTML某些标签--不 ...
- 错误ERROR datanode.DataNode (DataXceiver.java:run(278)) - hadoop07:50010DataXceiver error processing unknown operation src:127.0.0.136479 dst:127.0.0.150010
原因: Ambari 每分钟会向datanode发送"ping"连接一下去确保datanode是正常工作的.否则它会触发alert.但是datanode并没有处理空内容的逻辑,所以 ...
- 关于idea在运行web项目时部署的位置
(转) 以前一直很好奇,在idea中运行tomcat,把项目部署到其中,运行起来,然后我去tomcat目录下去看,根本找不到我部署的项目 那我的项目是咋运行的啊… - - 后来我就查啊查 ,纠结啊纠结 ...
- 2018-2019-2-20175332-实验二《Java面向对象程序设计》实验报告
一.单元测试 实验要求:参考 http://www.cnblogs.com/rocedu/p/6371315.html#SECUNITTEST 完成单元测试的学习 提交最后三个JUnit测试用例(正常 ...
- Windows将自己的代码发布到Github上
1.在GitHub上创建一个repository 2.在自己的电脑上选择工作的文件夹使用Git Bash clone刚刚创建的repository 3.此时本地git应该已经连接了GitHub,如果没 ...
- redis 初步认识三(设置登录密码)
1.cmd 2.cd C:\Program Files\Redis 3.redis-cli.exe -h 127.0.0.1 -a 123456