题意:给你一个n*n (n<=200)的字符串矩阵,问你每行每列都是回文串的最大的m*m的矩阵是多少

题解:首先答案不满足单调性,即m成立而m-1与m+1都却不一定成立,所以必须枚举答案确定现在的值是否成立,从大到小枚举就好

当枚举值为k时就转换为判断k是否为所求矩阵,判断时我们需要枚举每个点,(看从这个点开始是否向右向下都有连续k个回文串)

而我们可以分别找向右和向下,标记这个点向右或向下是否满足(从这个点开始是否向右向下都有连续k个回文串)

我们找向下时枚举每列每个向右k个字符是否为回文串

如果这个是回文,就在基础上加一否则基础就变成0(连续断掉),接着马上判断基础,大于k就在此位置前面k-1个位置标记为1

时间复杂度就是O(n^3),乘上前面的O(n)就过不了,但是我们可以预处理每个点向右,向下每个长度是否为回文串,这样就可以降O(n)的时间复杂度

预处理可以使用hash就是经典用法。但是一个更简单的方法就是dp,因为我们要找每段,则可以递归

#include<set>
#include<map>
#include<queue>
#include<stack>
#include<cmath>
#include<vector>
#include<string>
#include<cstdio>
#include<cstring>
#include<iomanip>
#include<stdlib.h>
#include<iostream>
#include<algorithm>
using namespace std;
#define eps 1E-8
/*注意可能会有输出-0.000*/
#define sgn(x) (x<-eps? -1 :x<eps? 0:1)//x为两个浮点数差的比较,注意返回整型
#define cvs(x) (x > 0.0 ? x+eps : x-eps)//浮点数转化
#define zero(x) (((x)>0?(x):-(x))<eps)//判断是否等于0
#define mul(a,b) (a<<b)
#define dir(a,b) (a>>b)
typedef long long ll;
typedef unsigned long long ull;
const int Inf=<<;
const ll INF=1ll<<;
const double Pi=acos(-1.0);
const int Mod=1e9+;
const int Max=;
const ull seed=1313ull;
ull base[Max],hashh[][Max];//求字符串hash值(前缀与后缀)
bool vis[][Max][Max];//固定答案时保存是否为回文
bool pal[Max][Max][][Max];//每个位置向左与向下每个长度是否为回文串
char str[Max][Max];
void Init(int n)
{
base[]=1ull;
for(int i=; i<n; ++i)
{
base[i]=base[i-]*seed;
}
return;
}
void InitPal(int n)
{
memset(pal,,sizeof(pal));
for(int i=; i<=n; ++i) //处理每个点的pal
{
for(int j=; j<=n; ++j)
{
hashh[][j-]=hashh[][j-]=0ull;
for(int k=j; k<=n; ++k)
{
hashh[][k]=hashh[][k-]*seed+(str[i][k]-'a'+1ull);
hashh[][k]=hashh[][k-]+(str[i][k]-'a'+1ull)*base[k-j];//后缀的hash
if(hashh[][k]==hashh[][k])
pal[i][j][][k-j+]=;//第i行第j个向右k-j个是否为回文串
//printf("%d ",pal[i][j][0][k-j+1]);
}
hashh[][i-]=hashh[][i-]=0ull;
for(int k=i; k<=n; ++k)
{
hashh[][k]=hashh[][k-]*seed+(str[k][j]-'a'+1ull);
hashh[][k]=hashh[][k-]+(str[k][j]-'a'+1ull)*base[k-i];//后缀的hash
if(hashh[][k]==hashh[][k])
pal[i][j][][k-i+]=;//第i行第j个向下k-j个是否为回文串
//printf("%d ",pal[i][j][1][k-i+1]);
}
//printf("\n");
}
}
}
int Jud(int ans,int n)//判断结果
{
memset(vis,,sizeof(vis));
for(int i=;i<=n;++i)//水平向右需要的是向下的回文串
{
int lev=,ver=;
for(int j=;j<=n;++j)
{
lev++;
if(!pal[i][j][][ans])//断开了
{
lev=;
}
if(lev>=ans)//此点左边ans个向下都是回文串
{
vis[][i][j-ans+]=;
} ver++;
if(!pal[j][i][][ans])//断开了
{
ver=;
}
if(ver>=ans)//此点下边ans个向右都是回文串
{
vis[][j-ans+][i]=;
}
}
}
for(int i=;i<=n;++i)
{
for(int j=;j<=n;++j)
{
if(vis[][i][j]&vis[][i][j])
return ;
}
}
return ;
}
int Solve(int n)
{
for(int i=n; i>; --i)//枚举结果
{
if(Jud(i,n))
return i;
}
return ;
}
int main()
{
Init(Max);
int n;
while(~scanf("%d",&n))
{
for(int i=; i<=n; ++i)
{
scanf("%s",str[i]+);
str[i][]='A';
}
InitPal(n);//初始化每个点向右玉向下每个位置是否为回文串
printf("%d\n",Solve(n));
}
return ;
}

SPOJ - PLSQUARE Palin Squar(hash+回文串)的更多相关文章

  1. bzoj 2124 等差子序列 树状数组维护hash+回文串

    等差子序列 Time Limit: 3 Sec  Memory Limit: 259 MBSubmit: 1919  Solved: 713[Submit][Status][Discuss] Desc ...

  2. bzoj 3768: spoj 4660 Binary palindrome二进制回文串

    Description 给定k个长度不超过L的01串,求有多少长度为n的01串S满足: 1.该串是回文串 2.该串不存在两个不重叠的子串,在给定的k个串中. 即不存在a<=b<c<= ...

  3. bzoj 3676 回文串 manachar+hash

    考虑每个回文串,它一定是它中心字母的最长回文串两侧去掉同样数量的字符后的一个子串. 所以我们可以用manachar求出每一位的回文半径,放到哈希表里并标记出它的下一个子串. 最后拓扑排序递推就行了.. ...

  4. Gym - 100570E:Palindrome Query (hash+BIT+二分维护回文串长度)

    题意:给定字符串char[],以及Q个操作,操作有三种: 1:pos,chr:把pos位置的字符改为chr 2:pos:问以pos为中心的回文串长度为多长. 3:pos:问以pos,pos+1为中心的 ...

  5. SPOJ STC02 - Antisymmetry(Manacher算法求回文串数)

    http://www.spoj.com/problems/STC02/en/ 题意:给出一个长度为n的字符串,问其中有多少个子串s可以使得s = s按位取反+翻转. 例如样例:11001011. 10 ...

  6. LOJ 2452 对称 Antisymmetry——用hash求回文串数

    概念 用hash求最长回文串/回文串数 首先,易知,回文串具有单调性. 如果字符串 $s[l...r]$ 为回文串串,那么 $s[x...y]$($l < x, y < r$ 且 $|l- ...

  7. [CSP-S模拟测试]:回文串(hash+二分)

    题目描述 $ASDFZ$的机房中不仅有红太阳,还有蓝太阳和原谅色太阳.有一天,太阳们来到机房,发现桌上有不知道哪个蒟蒻放上的问题:令$F(A,B)$表示选择一个串$A$的非空前缀$S$和串$B$的非空 ...

  8. CF452F等差子序列 & 线段树+hash查询区间是否为回文串

    记录一下一个新学的线段树基础trick(真就小学生trick呗) 给你一个1到n的排列,你需要判断该排列内部是否存在一个3个元素的子序列(可以不连续),使得这个子序列是等差序列.\(n\) <= ...

  9. POWEROJ 2610 判断回文串 【HASH】

    题目链接[https://www.oj.swust.edu.cn/problem/show/2610] 题意:给你一个字符串,让你判断这个字符串是不是回文串,字符串的长度是1<len<1e ...

随机推荐

  1. 行为驱动开发iOS <收藏>

    前段时间在design+code购买了一个学习iOS设计和编码在线课程,使用Sketch设计App,然后使用Swift语言实现Designer News客户端.作者Meng To已经开源到Github ...

  2. 【Redis安装学习】

    1.Redis 中文官网地址:http://www.redis.net.cn/download/ 这里只是简单的安装了下.具体的官网有详细的介绍和安装:跳转 如何安装 下载,解压,编译: $ wget ...

  3. qemu 源码调试

    1:下载最新的QEMU源码 git clone https://github.com/qemu/qemu.git 2:对qemu进行编译 ./configure --prefix=/usr --lib ...

  4. 【转】 jquery遍历json数组方法

    $(function () { var tbody = ""; //------------遍历对象 .each的使用------------- //对象语法JSON数据格式(当服 ...

  5. CH模拟赛 皇后游戏

    /* 做的时候手推了一下n=2的四种情况,再排一下序就可以了,证明不是很严谨,但我想这就行了,毕竟全是套路 */ #include<iostream> #include<cstdio ...

  6. codevs2216 行星序列

    题目描述 Description "神州"载人飞船的发射成功让小可可非常激动,他立志长大后要成为一名宇航员假期一始,他就报名参加了"小小宇航员夏令营",在这里小 ...

  7. 关于robotframework,app,appium的xpath定位问题及常用方法

    关于类似的帖子好像很多,但是没有找到具体能帮我解决问题的办法.还是自己深究了好久才基本知道app上面的xpath定位和web上的不同点: 先放一个图: A,先说说不用xpath的场景,一般是用于存在i ...

  8. Jni 调试 : eclipse + Vs 联合调试

    摘要: 本文原创,转载请注明地址 http://www.cnblogs.com/baokang/p/4982640.html 1.在Eclipse 中,Java 类中链接库引用到vs的debug目录下 ...

  9. How to create a Python dictionary with double quotes as default quote format?

    couples = [ ['jack', 'ilena'], ['arun', 'maya'], ['hari', 'aradhana'], ['bill', 'samantha']] pairs = ...

  10. 基础知识《十》unchecked异常和checked异常

    运行时异常在运行期间才能被检查出来,一般运行期异常不需要处理.也称为unchecked异常.Checked异常在编译时就能确定,Checked异常需要自己处理. checked 异常也就是我们经常遇到 ...