BZOJ 3790 神奇项链 Hash+二分+树状数组

题目大意:给定一个串,问这个串最少可以由回文串拼接多少次而成(拼接可以重叠)

首先将每两个字符之间插入占位符,然后Hash+二分搞出所有极大回文串(可以用manacher,我不会)

问题转化成了给定一些区间,求最少的能覆盖整个数轴的区间

将所有区间按照某一端点排序 然后上树状数组即可

回头还是去学学manacher吧。。。

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define M 100100
#define BASE 131
using namespace std;
typedef unsigned long long ll;
struct Interval{
	int x,y;
	bool operator < (const Interval &Y) const
	{
		return x < Y.x ;
	}
}intervals[M];
int n;
char s[M],_s[M<<1];
ll sum1[M<<1],sum2[M<<1],power[M<<1];
namespace BIT{
	int c[M];
	inline void Update(int x,int y)
	{
		for(;x;x-=x&-x)
			c[x]=min(c[x],y);
	}
	inline int Get_Ans(int x)
	{
		int re=0x3f3f3f3f;
		for(;x<=n;x+=x&-x)
			re=min(re,c[x]);
		return re;
	}
}
void Initialize()
{
	memset(_s,0,sizeof _s);
	memset(sum1,0,sizeof sum1);
	memset(sum2,0,sizeof sum2);
	memset(BIT::c,0x3f,sizeof BIT::c);
}
bool Judge(int x,int len)
{
	int l=x-len+1;
	int r=x+len-1;
	return  sum1[r]-sum1[l-1]*power[r-l+1]==
			sum2[l]-sum2[r+1]*power[r-l+1];
}
int Bisection(int x)
{
	int l=1,r=min(x,n-x+1);
	while(l+1<r)
	{
		int mid=l+r>>1;
		if( Judge(x,mid) )
			l=mid;
		else
			r=mid;
	}
	if( Judge(x,r) )
		return r;
	return l;
}
int main()
{
	int i;
	for(i=1,power[0]=1;i<M<<1;i++)
		power[i]=power[i-1]*BASE;
	while(~scanf("%s",s+1) )
	{
		Initialize();
		n=strlen(s+1);
		for(i=1;i<=n;i++)
		{
			_s[i<<1]=s[i];
			_s[i+i-1]='#';
		}
		_s[n=n+n+1]='#';
		for(i=1;i<=n;i++)
			sum1[i]=sum1[i-1]*BASE+_s[i];
		for(i=n;i;i--)
			sum2[i]=sum2[i+1]*BASE+_s[i];
		for(i=1;i<=n;i++)
		{
			int temp=Bisection(i);
			intervals[i].x=i-temp+1;
			intervals[i].y=i+temp-1;
		}
		sort(intervals+1,intervals+n+1);
		BIT::Update(1,-1);
		for(i=1;i<=n;i++)
		{
			int temp=BIT::Get_Ans(intervals[i].x);
			BIT::Update(intervals[i].y,temp+1);
		}
		printf("%d\n", BIT::Get_Ans(n) );
	}
}
时间: 2024-10-07 11:15:48

BZOJ 3790 神奇项链 Hash+二分+树状数组的相关文章

BZOJ 3790 神奇项链 Hash+二分

题目大意:给出一个字符串,求出这是最少由多少个回文串组成的.回文串可以重叠. 思路:将原串中的所有回文串都统计出来,然后变成一些区间,问题就转化成了区间并的问题. CODE: #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define MAX 400010 #define BASE 1333 #define INF 0x3f3f3f3f using

BZOJ 3790 神奇项链 hash/后缀自动机+贪心

Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小写字母组成的字符串,每个小写字母表示一种颜色. 为了制作这个项链,小 H 购买了两个机器.第一个机器可以生成所有形式的回文串,第二个机器可以把两个回文串连接起来,而且第二个机器还有一个特殊的性质:假如一个字符串的后缀和一个字符串的前缀是完全相同的,那么可以将这个重复部分重叠.例如:aba和aca连接起来,可以生成串abaaca或 abaca. 现在给出目标项链的样式,询问你需要使用第二个机器多少次才

11525 - Permutation(二分+树状数组)

题目链接:点击打开链接 题意:从1~k的所有排列中找到第n个排列, n由公式给出. 思路:可以发现, 这个公式就是康托展开公式(康托展开百科:点击打开链接). 那么s[i]的意思就是i个数中当前数排在第几. 如此, 可以用二分+树状数组快速求解, 和一道BC题目神似. 细节参见代码: #include<cstdio> #include<cstring> #include<algorithm> #include<iostream> #include<st

Codeforces 374D Inna and Sequence 二分+树状数组

题目链接:点击打开链接 给定n个操作,m长的序列a 下面n个数 if(co>=0)则向字符串添加一个co (开始是空字符串) else 删除字符串中有a的下标的字符 直接在序列上搞,简单模拟 #include<stdio.h> #include<iostream> #include<string.h> #include<set> #include<vector> #include<map> #include<math.h&

【bzoj2527】[Poi2011]Meteors 整体二分+树状数组

题目描述 有N个成员国.现在它发现了一颗新的星球,这颗星球的轨道被分为M份(第M份和第1份相邻),第i份上有第Ai个国家的太空站. 这个星球经常会下陨石雨.BIU已经预测了接下来K场陨石雨的情况.BIU的第i个成员国希望能够收集Pi单位的陨石样本.你的任务是判断对于每个国家,它需要在第几次陨石雨之后,才能收集足够的陨石. 输入 第一行是两个数N,M. 第二行有M个数,第i个数Oi表示第i段轨道上有第Oi个国家的太空站. 第三行有N个数,第i个数Pi表示第i个国家希望收集的陨石数量. 第四行有一个

【51nod】 第K大区间2(二分+树状数组)

[51nod] 第K大区间2(二分+树状数组) 第K大区间2 ﹡    LH (命题人) 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 160 定义一个长度为奇数的区间的值为其所包含的的元素的中位数.中位数_百度百科 现给出n个数,求将所有长度为奇数的区间的值排序后,第K大的值为多少. 样例解释: [l,r]表示区间的值 [1]:3 [2]:1 [3]:2 [4]:4 [1,3]:2 [2,4]:2 第三大是2 Input 第一行两个数n和k(1<=n<=100000,k&l

BZOJ 3211 花神游历各国 (树状数组+并查集)

题解:首先,单点修改求区间和可以用树状数组实现,因为开平方很耗时间,所以在这个方面可以优化,我们知道,开平方开几次之后数字就会等于1 ,所以,用数组记录下一个应该开的数,每次直接跳到下一个不是1的数字进行开平方,至于这个数组,可以用并查集维护. #include <cstdio> #include <cmath> #include <iostream> using namespace std; typedef long long LL; LL c[100005]; in

【BZOJ3110】【整体二分+树状数组区间修改/线段树】K大数查询

Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少. Input 第一行N,M 接下来M行,每行形如1 a b c或2 a b c Output 输出每个询问的结果 Sample Input 2 5 1 1 2 1 1 1 2 2 2 1 1 2 2 1 1 1 2 1 2 3 Sample Output 1 2 1 HINT

【BZOJ-2527】Meteors 整体二分 + 树状数组

2527: [Poi2011]Meteors Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 831  Solved: 306[Submit][Status][Discuss] Description Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby galaxy. The planet is unsuitable for colo