题目大意:
两个字符串相似定义为:
1.两个字符串长度相等
2.两个字符串对应位置上有且仅有至多一个位置所对应的字符不相同
给定一个字符串,每次询问两个子串在给定的规则下是否相似。给定的规则指每次给出一些等价关系,如‘a'=’b',‘b'=’c'等,注意这里的等价关系具有传递性,即若‘a'=’b',‘b'=’c',则‘a'=’c'。
解题报告:
正解:哈希+二分
我们先处理出每一个字母哈希值的前缀和,然后并查集维护等价关系,对于相似的判断,如果两串的哈希值完全一样,就为YES,如果存在一个字符不一样,那么我们就二分那个位置,判断左右哈希值是否相等,如果两端哈希值都不相等,说明存在两个以上的位置不相同,判为NO
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#define RG register
#define il inline
#define iter iterator
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long long ll;
const int N=300005;
ll p=20021021,mod=1e9+7,ha[N][26],mul[N];
char S[N],sc[5];int n,a[N],fa[27];
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
ll query(int l,int r){
ll ret=0,x;
for(int i=0;i<26;i++){
x=((ha[r][i]-(ha[l-1][i]*mul[r-l+1])%mod)+mod)%mod;
ret=(ret+x*(find(i)+1))%mod;
}
return ret;
}
void work()
{
scanf("%s",S+1);
n=strlen(S+1);
for(int i=1;i<=n;i++)a[i]=S[i]-'a';
mul[0]=1;for(int i=1;i<=n;i++)mul[i]=mul[i-1]*p%mod;
for(int i=1;i<=n;i++){
for(int j=0;j<26;j++)
ha[i][j]=ha[i-1][j]*p%mod;
(ha[i][a[i]]+=1)%=mod;
}
int Q,Ls,Rs,Lt,Rt,m,l,r,mid,Hl,Hr,Hll,Hrr,flag;
scanf("%d",&Q);
while(Q--){
scanf("%d%d%d%d%d",&m,&Ls,&Rs,&Lt,&Rt);
for(int i=0;i<26;i++)fa[i]=i;
for(int i=1;i<=m;i++){
scanf("%s",sc);
if(find(sc[0]-'a')!=find(sc[1]-'a'))
fa[find(sc[1]-'a')]=find(sc[0]-'a');
}
if(Rt-Lt!=Rs-Ls){puts("NO");continue;}
if(query(Lt,Rt)==query(Ls,Rs)){puts("YES");continue;}
l=1;r=Rt-Lt+1;flag=0;
while(l<=r){
mid=(l+r)>>1;
Hl=query(Ls,Ls+mid-1);Hr=query(Lt,Lt+mid-1);
Hll=query(Ls+mid,Rs);Hrr=query(Lt+mid,Rt);
if(Hl!=Hr && Hll!=Hrr){flag=1;break;}
if(Hl!=Hr)r=mid-1;
else l=mid+1;
}
if(flag)puts("NO");
else puts("YES");
}
}
int main()
{
work();
return 0;
}
51Nod 1753 相似子串的更多相关文章
-
51nod 1286 三段子串(树状数组+拓展kmp)
题意: 给定一个字符串S,找到另外一个字符串T,T既是S的前缀,也是S的后缀,并且在中间某个地方也出现一次,并且这三次出现不重合.求T最长的长度. 例如:S = "abababababa&q ...
-
51 NOD 1753 相似子串 字符串hash
1735 相似子串 基准时间限制:5 秒 空间限制:131072 KB 分值: 80 两个字符串相似定义为:1.两个字符串长度相等2.两个字符串对应位置上有且仅有至多一个位置所对应的字符不 ...
-
NOIP2018提高组金牌训练营——字符串专题
NOIP2018提高组金牌训练营——字符串专题 1154 回文串划分 有一个字符串S,求S最少可以被划分为多少个回文串. 例如:abbaabaa,有多种划分方式. a|bb|aabaa - 3 个 ...
-
(最长回文子串 线性DP) 51nod 1088 最长回文子串
输入一个字符串Str,输出Str里最长回文子串的长度. 回文串:指aba.abba.cccbccc.aaaa这种左右对称的字符串. 串的子串:一个串的子串指此(字符)串中连续的一部分字符构成的子(字符 ...
-
51Nod 算法马拉松28 B题 相似子串 哈希
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - 51Nod1753 题意概括 两个字符串相似定义为: 1.两个字符串长度相等 2.两个字符串对应位置上有且仅有 ...
-
51Nod 1089:最长回文子串 V2(Manacher算法)
1089 最长回文子串 V2(Manacher算法) 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 回文串是指aba.abba.cccbccc.aaa ...
-
51Nod 1088:最长回文子串(暴力)
1088 最长回文子串 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 回文串是指aba.abba.cccbccc.aaaa这种左右对称的字符串. 输入 ...
-
51nod 1089 最长回文子串 V2(Manacher算法)
回文串是指aba.abba.cccbccc.aaaa这种左右对称的字符串. 输入一个字符串Str,输出Str里最长回文子串的长度. 收起 输入 输入Str(Str的长度 <= 100000) ...
-
51nod 1088 最长回文子串 【中心拓展法/输出长度和路径】
1088 最长回文子串 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 回文串是指aba.abba.cccbccc.aaaa这种左右对称的字符串. 输入一个字 ...
随机推荐
-
如何实现一个php框架系列文章【5】安全处理输入
所有的外部输入参数都应该检查合法性. 未正确处理输入数据将可能导致sql注入等漏洞. 框架提供系列函数来取$_REQUEST中的值 requestInt requestString requestFl ...
-
PHP 递归创建目录
/* 用迭代的方法递归创建目录 其实在PHP5.0.0之后mkdir就已经能递归创建目录了. 这里主要是自己学习迭代,所以拿创建级联目录开刀了. 开发中应该写mkdir('./a/b/c/d/e',0 ...
-
更方便的函数回调——Lambda
auto callbackFunc = [&](){ backHome(); }; []符号,表示要开始一个lambda函数: ()符号,里面填写函数的参数: 当想在lambda函数里使用外部 ...
-
Java程序初始化的顺序
Java程序初始化的顺序 java程序初始化工作可以在许多不同的代码块中来完成(例如:静态代码块.构造函数等),他们执行的顺序如下: 父类静态变量 父类静态代码块 子类静态变量 子类静态代码块 父类非 ...
-
linux下64位汇编的系统调用(1)
现在基本上系统都是64位了,而64位系统下的汇编和32位有了较大的变化,无论是系统调用的接口还是C标准库的接口都和32位汇编有所不同:下面简单谈一下在64位linux下如何利用汇编直接调用系统调用. ...
-
逆向实战干货,植物大战僵尸快速定位自动捡阳光Call,或者标志
逆向实战干货,快速定位自动捡阳光Call,或者标志 注意: 关于CE和OD的使用,这里不再多说,快速定位,默认大家已经有了CE基础,或者OD基础. 第一种方法,找Call 第一步,打开CE,搜索阳光值 ...
-
python使用pudb调试
pudb是pdb的升级版本 安装 pip3 install pudb 使用方法 在程序文件的开头导入包 from pudb import set_trace set_trace()#断点位置 运行的时 ...
-
vim 命令学习(高级篇)
[1]打开文件方式 (1)vim +n filename 作用:打开文件,并定位到第n行 例如:vim +103 2019-02-26-errorrepeat.txt 效果:打开2019-02-26- ...
-
javascript 缓动返回顶部案例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
-
IT阅读——关于“业务”
本文转自http://www.cnblogs.com/beijiguangyong/archive/2012/11/12/2767054.html 开发当中常常听说“业务”这个词,什么“业务为王”之类 ...