BZOJ 3790 神奇项链(manacher+DP+树状数组)
【题目链接】 http://www.lydsy.com/JudgeOnline/problem.php?id=3790
【题目大意】
问最少用几个回文串可以构成给出串,重叠部分可以合并
【题解】
我们先用manacher处理出每个位置最长的回文串,
那么题目就转化为求最少的线段来覆盖全区间,那就是经典的dp题了,
dp[i]=min(dp[j]+1)(i线段的左端点-1和j线段的右端点有交)
用树状数组优化一下即可。
【代码】
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
char s[100010],a[50010];
const int INF=0x3f3f3f3f;
int cnt,n,c[100010],f[100010];
struct seg{int l,r;}l[100010];
void add_edge(int x,int y){
x=x/2+1; y=y/2-1;
if(x>y)return;
l[++cnt]=(seg){x,y};
//printf("%d %d\n",x,y);
}
bool operator <(seg a,seg b){return a.r<b.r;}
void update(int x,int val){while(x)c[x]=min(c[x],val),x-=x&-x;}
int query(int x){if(!x)return 0;int res=INF;while(x<=n)res=min(c[x],res),x+=x&-x;return res;}
void manacher(char *a){
int m,r,p,i;
for(i=1;i<=n;i++)s[i<<1]=a[i],s[i<<1|1]='#';
s[0]='$',s[1]='#',s[m=(n+1)<<1]='@';
for(r=p=0,f[1]=1,i=2;i<m;i++){
for(f[i]=r>i?min(r-i,f[p*2-i]):1;s[i-f[i]]==s[i+f[i]];f[i]++);
add_edge(i-f[i],i+f[i]);
if(i+f[i]>r)r=i+f[i],p=i;
}
} int main(){
while(~scanf("%s",a+1)){
n=strlen(a+1); cnt=0;
for(int i=1;i<=n;i++)c[i]=INF;
manacher(a);
sort(l+1,l+cnt+1);
int ans=INF,tmp;
for(int i=1;i<=cnt;i++){
update(l[i].r,tmp=query(l[i].l-1)+1);
if(l[i].r==n)ans=min(ans,tmp);
}printf("%d\n",ans-1);
}return 0;
}
BZOJ 3790 神奇项链(manacher+DP+树状数组)的更多相关文章
- BZOJ 3790: 神奇项链 [Manacher 贪心]
3790: 神奇项链 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 405 Solved: 200[Submit][Status][Discuss] ...
- BZOJ.4553.[HEOI2016&TJOI2016]序列(DP 树状数组套线段树/二维线段树(MLE) 动态开点)
题目链接:BZOJ 洛谷 \(O(n^2)\)DP很好写,对于当前的i从之前满足条件的j中选一个最大值,\(dp[i]=d[j]+1\) for(int j=1; j<i; ++j) if(a[ ...
- BZOJ 4361 isn 容斥+dp+树状数组
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4361 题意概述: 给出一个长度为N的序列A(A1,A2...AN).如果序列A不是非降的 ...
- bzoj 1264 [AHOI2006]基因匹配Match(DP+树状数组)
1264: [AHOI2006]基因匹配Match Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 793 Solved: 503[Submit][S ...
- BZOJ 1264: [AHOI2006]基因匹配Match 树状数组+DP
1264: [AHOI2006]基因匹配Match Description 基因匹配(match) 卡卡昨天晚上做梦梦见他和可可来到了另外一个星球,这个星球上生物的DNA序列由无数种碱基排列而成(地球 ...
- 树形DP+树状数组 HDU 5877 Weak Pair
//树形DP+树状数组 HDU 5877 Weak Pair // 思路:用树状数组每次加k/a[i],每个节点ans+=Sum(a[i]) 表示每次加大于等于a[i]的值 // 这道题要离散化 #i ...
- 【bzoj2274】[Usaco2011 Feb]Generic Cow Protests dp+树状数组
题目描述 Farmer John's N (1 <= N <= 100,000) cows are lined up in a row andnumbered 1..N. The cows ...
- 奶牛抗议 DP 树状数组
奶牛抗议 DP 树状数组 USACO的题太猛了 容易想到\(DP\),设\(f[i]\)表示为在第\(i\)位时方案数,转移方程: \[ f[i]=\sum f[j]\;(j< i,sum[i] ...
- BZOJ 3790 神奇项链(manacher+贪心)
3790: 神奇项链 Time Limit: 10 Sec Memory Limit: 64 MB Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小 ...
随机推荐
- spring 那点事
Spring核心功能 DI(IOC) 何谓DI(IOC) DI(依赖注入)是spring的核心功能之一. Dependency Injection 和 Inversion of Control 其实就 ...
- Centos 6.5下安装vsftpd服务器
1.查看是否安装vsftp [root@localhost ~]#rpm -qa|grep vsftpd 如果出现 vsftpd-2.2.2-13.el6_6.1.x86_64 则说明已经安装了v ...
- Winform GDI+
什么是GDI+ GDI (Graphics Device Interface), 是属于绘图方面的 API (Application Programming Interface). 因为应用程序不能直 ...
- 【Python学习笔记】colormap的参数及其对应的色条
- C++学习之路(六):实现一个String类
直接贴代码吧,这段时间准备面试也正好练习了一下. class String { public: String(const char *str = ""); ~String(void ...
- "Flags mismatch irq" register interrupt handler error
Question : When you see the log "Flags mismatch irq ............", maybe you use the same ...
- Linux平台用C++实现事件对象,同步线程(转)
本文属于转载,原文链接如下:http://blog.csdn.net/chexlong/article/details/7080537 与其相关的一组API包括:pthread_mutex_init, ...
- windows server 2012 IIS配置之FTP站点
原文地址:[原创]winserver2012IIS配置之FTP站点作者:hkmysterious 一.实验拓扑: 使server2012客户计算机通过ftp方式从FTP服务器上下载已上传并共享的文 ...
- [PAT] 1140 Look-and-say Sequence(20 分)
1140 Look-and-say Sequence(20 分)Look-and-say sequence is a sequence of integers as the following: D, ...
- JAX-RS Resteasy
JAX-RS (JSR-311) 是为 Java EE 环境下的 RESTful 服务能力提供的一种规范.它能提供对传统的基于 SOAP 的 Web 服务的一种可行替代. https://www.ib ...