bzoj 3790 神奇项链(Manacher,DP+BIT | 贪心)
【题意】
你可以产生一个回文串,也可以将两个串合并成一个串,问产生目标串需要的最少合并次数。
【思路】
显然我们要先产生目标串中包含的极大回文字符串。
Manacher求出每个位置可以向两边延伸的最长回文串。
则题目转化为有若干条线段,求最少的线段将[1..n]覆盖。贪心DP皆可上,DP需要BIT优化一下。
【代码】
#include<set>
#include<cmath>
#include<queue>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define trav(u,i) for(int i=front[u];i;i=e[i].nxt)
#define FOR(a,b,c) for(int a=(b);a<=(c);a++)
using namespace std; typedef long long ll;
const int N = 2e5+;
const int inf = 1e9; struct Node
{
int l,r;
bool operator < (const Node& rhs) const
{
return r<rhs.r;
}
} q[N];
int tot; char s[N],a[N];
int n,m,p[N]; int C[N];
void upd(int x,int v)
{
for(int i=x;i;i-=i&(-i))
C[i]=min(C[i],v);
}
int query(int x)
{
if(x==) return ;
int res=inf;
for(int i=x;i<=n;i+=i&(-i))
res=min(res,C[i]);
return res;
} void Add(int l,int r)
{
l=l/+,r=r/-;
if(l>r) return ;
q[++tot]=(Node){l,r};
}
void Manacher()
{
m=*n+;
for(int i=;i<=n;i++)
{
a[i<<]=s[i];
a[i<<|]='#';
}
a[]='+',a[m+]='-',a[]='#';
int mx=,id;
for(int i=;i<=m;i++)
{
if(mx>i) p[i]=min(mx-i,p[id*-i]);
else p[i]=;
while(a[i-p[i]]==a[i+p[i]]) p[i]++;
Add(i-p[i],i+p[i]);
if(p[i]+i>mx) mx=i+p[i],id=i;
}
} int dp()
{
int ans=inf;
sort(q+,q+tot+);
FOR(i,,tot)
{
int x=query(q[i].l-)+;
upd(q[i].r,x);
if(q[i].r==n) ans=min(ans,x);
}
return ans;
} int main()
{
while(scanf("%s",s+)==)
{
memset(p,,sizeof(p));
tot=;
n=strlen(s+);
FOR(i,,n) C[i]=inf;
Manacher();
printf("%d\n",dp()-);
}
return ;
}
bzoj 3790 神奇项链(Manacher,DP+BIT | 贪心)的更多相关文章
- BZOJ 3790: 神奇项链 [Manacher 贪心]
		
3790: 神奇项链 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 405 Solved: 200[Submit][Status][Discuss] ...
 - BZOJ 3790 神奇项链 hash/后缀自动机+贪心
		
Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小写字母组成的字符串,每个小写字母表示一种颜色. 为了制作这个项链,小 H 购买了两个机器.第一个机器可 ...
 - BZOJ 3790 神奇项链(manacher+贪心)
		
3790: 神奇项链 Time Limit: 10 Sec Memory Limit: 64 MB Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小 ...
 - bzoj 3790: 神奇项链
		
3790: 神奇项链 Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小写字 母组成的字符串,每个小写字母表示一种颜色.为了制作这个项链,小 H 购买了 ...
 - bzoj 3790 神奇项链 回文串 manacher|PAM
		
LINK:神奇项链 存在两个操作:1. 一个操作可以生成所有形式的回文串 2.一个操作可以将两个串给合并起来 如果前缀和后缀相同还可以将其并起来. 多组询问 每次询问合成一个串所需最少多少次2操作. ...
 - BZOJ 3790 神奇项链(manacher+DP+树状数组)
		
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3790 [题目大意] 问最少用几个回文串可以构成给出串,重叠部分可以合并 [题解] 我们 ...
 - BZOJ 3790 神奇项链(回文自动机+线段树优化DP)
		
我们预处理出来以i为结尾的最长回文后缀(回文自动机的构建过程中就可以求出)然后就是一个区间覆盖,因为我懒得写贪心,就写了线段树优化的DP. #include<iostream> #incl ...
 - 【BZOJ-3790】神奇项链      Manacher + 树状数组(奇葩) + DP
		
3790: 神奇项链 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 304 Solved: 150[Submit][Status][Discuss] ...
 - 【BZOJ3790】神奇项链 Manacher+贪心
		
[BZOJ3790]神奇项链 Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小写字 母组成的字符串,每个小写字母表示一种颜色.为了制作这个项链,小 H ...
 
随机推荐
- 最近JavaScript的一些收获
			
开发习惯的上的收获 1,开发过程中,要让整个逻辑展示在一个函数中,中间部分则做可以考虑公用策略优化 2,开发完成至少有三个角度进行测试,正面方面和中立 开发技巧上面的收获 1,驼峰转为‘-’以及‘-’ ...
 - HBase 架构与工作原理3 - HBase 读写与删除原理
			
本文系转载,如有侵权,请联系我:likui0913@gmail.com 一.前言 在 HBase 中,Region 是有效性和分布的基本单位,这通常也是我们在维护时能直接操作的最小单位.比如当一个集群 ...
 - [洛谷P5081]Tweetuzki 爱取球
			
题目大意:有$n$个球,每一次取一个球然后放回,问期望多少次取遍所有球 题解:令$f_i$表示已经取了$i$种球,还要取的次数的期望.$f_i=\dfrac in(f_i+1)+\dfrac{n-i} ...
 - Docker Machine 和 Docker Engine 的区别
			
Docker Engine 当人们提到 Docker,一般而言,大家说的是 Docker Engine,如下图: 它是一个 client-server application. Docker Eng ...
 - Java之使用链表实现队列
			
import java.util.Iterator; import java.util.NoSuchElementException; /** * 使用链表来实现队列 * 1.考虑结点的结构,包括当前 ...
 - Luogu1309 瑞士轮(分治,归并排序)
			
Luogu1309 瑞士轮(分治,归并排序) Description 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然 ...
 - fzyzojP3580 -- [校内训练-互测20180315]小基的高智商测试
			
题目还有一个条件是,x>y的y只会出现一次(每个数直接大于它的只有一个) n<=5000 是[HNOI2015]实验比较 的加强版 g(i,j,k)其实可以递推:g(i,j,k)=g(i- ...
 - [USACO10OPEN]牛跳房子Cow Hopscotch
			
题目描述 奶牛们正在回味童年,玩一个类似跳格子的游戏,在这个游戏里,奶 牛们在草地上画了一行N个格子,(3 <=N <= 250,000),编号为1..N. 就像任何一个好游戏一样,这样的 ...
 - D. Mahmoud and Ehab and the binary string Codeforces Round #435 (Div. 2)
			
http://codeforces.com/contest/862/problem/D 交互题 fflush(stdout) 调试: 先行给出结果,函数代替输入 #include <cstdio ...
 - 我的第一个activiti实例 (代码方式) ctiviti入门列子一个简单的activiti请假流程
			
转: (activiti入门列子一个简单的activiti请假流程) 我的第一个activiti实例 2017年05月31日 14:29:45 chf_mixueer 阅读数:1223 整个项目的 ...