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 ...
随机推荐
- linux配置java开发环境
一.下载jdk java -version 查看有没有安装jdk 下载对应版本的jdk:jdk-java7u60-linux-x64.tar.gz 二.解压 cp jdk-java7u60-lin ...
- Win7如何删除需要管理员权限才能删除的文件夹
在Windows 7系统运行中.往往会遇到想要删除某个文件夹时,系统提示:文件夹访问被拒绝 你需要权限来执行此操作,如何才能删除此类文件夹呢? ------------------ --------- ...
- nltk27_NLTK聚类分析
http://www.pythontip.com/blog/post/10044/ Python自然语言处理(三) -- 利用NLTK进行聚类 这篇文章介绍如何利用NLTK进行聚类,和上两篇文章Pyt ...
- 20145204&20145212信息安全系统实验一报告
信息安全系统实验报告 实验一 步骤 1.连接 arm 开发板 将 arm 开发板的电源线接好,使得开发板开关处于闭合状态.再分别将串口线.并口线和网线与 pc 机连接好. 2.建立超级终端 运行 wi ...
- C++ GC
http://www.codeproject.com/Articles/912/A-garbage-collection-framework-for-C http://www.codeproject. ...
- Class PLBuildVersion is implemented in both /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/System/Library/PrivateFrameworks/AssetsLibr
网上找了一大堆,没有解决的办法 ,主要是iOS10的适配问题,info.plist里没有加对. 访问相册,我只加了 <!-- 相册 --> <key>NSPhotoLibrar ...
- 第三次个人作业—“K米”评测
第一部分 调研,评测 评测 1.上手体验: 软件欢迎界面,色彩对比鲜明,前三图深色调,最后一条则充满了艳丽的色彩,让人对这个产品突然充满了期待. 软件界面加载速度慢,很多地方点击进去要等好久才能出现界 ...
- java基础 集合类
java集合类主要有以下集中: List结构的集合类: ArrayList类, LinkedList类, Vector类, Stack类 Map结构的集合类: HashMap类,Hashtable类 ...
- error 502 in ngin php5-fpm
unix:/var/run/php5-fpm.sock failed (11: Resource temporarily unavailable) http://stackoverflow.com/q ...
- MineCraft note
客户端:http://pan.baidu.com/s/1hqgS8sshttp://pan.baidu.com/s/1mgmkduC 材质包:R3D小地图MODCraftGuide mod 内置合成表 ...