ZZULI 1876: 蛤玮的项链 Hash + 二分
Time Limit: 6 Sec Memory Limit: 128 MB
Submit: 153 Solved: 11
Description
Input
Output
Sample Input
Sample Output
HINT
思路:(dzs教我的)。由于是循环的,那么将s变为ss,类似用hash求以i为中心的最长回文的长度,对于每一个位置i,先二分到pos1,那么pos1-i-(i-pos1+i)为当前的回文段,pos1-=2,相当于修改一次操作,继续二分到一个位置pos2.如此做两次,就相当于两次修改操作
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>
#include <map>
#include <string>
using namespace std;
const int x = ;
const int N = ;
unsigned long long H1[N], H2[N], xp[N];
char s[N];
int n, m;
void initHash() {
H1[n] = H2[n] = ;
int t = ;
for(int i = n - ; i >= ; --i) {
H2[i] = H2[i + ] * x + s[i];
H1[i] = H1[i + ] * x + s[t++];
}
xp[] = ;
for(int i = ; i <= n; ++i) xp[i] = xp[i - ] * x;
}
unsigned long long getHash(int i, int L, int f) {
unsigned long long h;
if(f == )
h = H1[i] - H1[i + L] * xp[L];
else
h = H2[i] - H2[i + L] * xp[L];
return h;
}
void init() {
scanf("%s", s);
m = strlen(s);
for(int i = ; i < m; ++i) s[i + m] = s[i];
n = m << ;
initHash();
}
int get(int i) {
int L = , R = i + ;
while(R - L > ) {
int M = (L + R) >> ;
if(n - i + M <= n && i + + M <= n && getHash(n - i, M, ) == getHash(i + , M, ))
L = M;
else R = M;
}
return L;
}
int change(int i, int cen) {
int L = , R = i + ;
while(R - L > ) {
int M = (L + R) >> ;
if(n - i - + M <= n && * cen - i + M <= n && getHash(n - i - , M, ) == getHash( * cen - i, M, ))
L = M;
else R = M;
}
return L;
}
int solve() {
int pos1, pos2, pos3, ls1, ls2;
if(m <= ) return m;
int ans = ;
for(int i = ; i < n; ++i)
{
int x = get(i);
pos1 = i - x;
if(x + + i < n) pos1 -= ;
ls1 = change(pos1, i);
pos2 = pos1 - ls1 + ;
if(pos2 == && i - pos2 + i + < n) pos3 = ;
else if(pos2 == ) pos3 = pos2;
else {
pos3 = pos2;
if(i - pos2 + i + < n) {
pos2 -= ;
ls2 = change(pos2, i);
pos3 = pos2 - ls2 + ;
}
}
ans = max(ans, (i - pos3) * + );
}
return min(m, ans);
}
int main() {
// freopen("in", "r", stdin);
int _; scanf("%d", &_);
while(_ --) {
init();
int ans = solve();
if(ans % == ) ans--;
printf("%d\n", ans);
}
return ;
} /**************************************************************
Problem: 1876
User: atrp
Language: C++
Result: Accepted
Time:2676 ms
Memory:6208 kb
****************************************************************/
ZZULI 1876: 蛤玮的项链 Hash + 二分的更多相关文章
- NBOJv2 Problem 1009 蛤玮的魔法(二分)
Problem 1009: 蛤玮的魔法 Time Limits: 1000 MS Memory Limits: 65536 KB 64-bit interger IO format: %ll ...
- 线段树区间覆盖 蛤玮打扫教室(zzuli 1877)
http://acm.zzuli.edu.cn/zzuliacm/problem.php?id=1877 Description 现在知道一共有n个机房,算上蛤玮一共有m个队员,教练做了m个签,每 ...
- 【BZOJ】1014: [JSOI2008]火星人prefix(splay+hash+二分+lcp)
http://www.lydsy.com/JudgeOnline/problem.php?id=1014 题意:支持插入一个字符.修改一个字符,查询lcp.(总长度<=100000, 操作< ...
- NBOJv2 1004 蛤玮打扫教室(线段树区间更新区间最值查询)
Problem 1004: 蛤玮打扫教室 Time Limits: 1000 MS Memory Limits: 65536 KB 64-bit interger IO format: %l ...
- LOJ#6387 「THUPC2018」绿绿与串串 / String (Manacher || hash+二分)
题目描述 绿绿和 Yazid 是好朋友.他们在一起做串串游戏. 我们定义翻转的操作:把一个串以最后一个字符作对称轴进行翻转复制.形式化地描述就是,如果他翻转的串为 RRR,那么他会将前 ∣R∣−1个字 ...
- POJ 1743 Musical Theme (字符串HASH+二分)
Musical Theme Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 15900 Accepted: 5494 De ...
- Codeforces 1090J $kmp+hash+$二分
题意 给出两个字符串\(s\)和\(t\),设\(S\)为\(s\)的任意一个非空前缀,\(T\)为\(t\)的任意一个非空前缀,问\(S+T\)有多少种不同的可能. Solution 看了一圈,感觉 ...
- bzoj1014: [JSOI2008]火星人prefix(splay+hash+二分)
题目大意:一个字符串三个操作:①求两个后缀的LCP②插入一个字符③修改一个字符. 前几天刚学了hash+二分求lcp,就看到这题. 原来splay还能这么用?!原来splay模板这么好写?我以前写的s ...
- bnuoj 34990(后缀数组 或 hash+二分)
后缀数组倍增算法超时,听说用3DC可以勉强过,不愿写了,直接用hash+二分求出log(n)的时间查询两个字符串之间的任意两个位置的最长前缀. 我自己在想hash的时候一直在考虑hash成数值时MOD ...
随机推荐
- J2EE web项目中解决所有路径问题
Java中使用的路径,分为两种:绝对路径和相对路径.归根结底,Java本质上只能使用绝对路径来寻找资源.所有的相对路径寻找资源的方法,都不过是一些便利方法.不过是API在底层帮助我们构建了绝对路径,从 ...
- mysql设置远程访问权限
查一下你的MYSQL用户表里, 是否允许远程连接 1.授权 mysql>grant all privileges on *.* to 'root'@'%' identified by ...
- php操作mongodb
<?php set_time_limit(0); $mongo = new Mongo('192.168.33.50:27017'); //连接远程主机22011端口 $db = $mongo- ...
- 让Web页面中的编辑器支持黏贴或直接拖拽来添加图片
基本原理是将剪贴板中的图片二进制数据转为Base64编码 代码: <html> <head> </head> <body> <script src ...
- SQL SERVER批量修改表名前缀
比如前缀由mms_修改为 ets_ exec sp_msforeachtable @command1=' declare @o sysname,@n sysname ...
- Windows环境配置HTTP服务(Windows + Apache + Mysql + PHP)
1.安装WampServer 2.管理HTTP服务 任务图标绿色为正常启动状态 注意事项:1.检查网络是不是通的 ping 对方IP2.检查防火墙是否开启,如果开启将不能正常被访问3.检查访问权限 A ...
- poj 1141
简单的dp 忘了\n,调了半天(目测不是第一次了) 直接贴代码: #include<cstdio> #include<cstring> using namespace std; ...
- BZOJ2007——[Noi2010]海拔
1.题意:一个裸的最小割 2.分析:直接转成对偶图最短路就好了,水爆了!(雾) #include <queue> #include <cstdio> #include < ...
- 耿丹CS16-2班第一次作业汇总
第一次作业统计完成. 注:1.作业顺序:取最早交作业的前3名,依次拿5,2,1分,前提是作业质量较高,否则轮至下一名同学得分,其余同学得0分:2.作业情况:满10分,空一题扣2分,心得写得好的有额外加 ...
- 安装rabbitmq
安装配置epel源 $ rpm -ivh http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm 安装erlan ...