题解 [51nod1753] 相似子串

题面

解析

先考虑相等的时候怎么办,

我们考虑求出每个字母的贡献,这样字母相等的问题就可以用并查集来解决.

具体来说,我们先对于每个字母,把S中等于它的标为1,其它的标为0,

那么S对于每个字母都有一个01串的形式,

再考虑对每个01串hash,

在统计答案的时候就枚举字母将它的hash值加到它并查集的贡献里去.

再考虑有一个不相等的情况,

这时设一个字符为a1,另一个为a2,

那么只有这两个字母的贡献不一样,

而这两个字母的贡献的值肯定是hash用的p进制的p的非负整数幂,

于是用map存一下p的非负整数幂就好了.

code:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <map>
#define ll long long
#define fre(x) freopen(x".in","r",stdin),freopen(x".out","w",stdout)
using namespace std; inline int read(){
int sum=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){sum=sum*10+ch-'0';ch=getchar();}
return f*sum;
} const int N=300005;
const int P=199999;
const int Mod=1000000007;
int n,t,s[N],da[N];
ll has[27][N],f[2][27],po[N];
char S[N],T[5];
map<ll,int> mp; inline void init(){
for(int i=0;i<=26;i++) da[i]=i;
memset(f,0,sizeof(f));
} inline int find(int x){
return da[x]==x? x:da[x]=find(da[x]);
} inline int get(int i,int l,int r){
return ((has[i][r]-has[i][l-1]*po[r-l+1])%Mod+Mod)%Mod;
} inline void solve(){
init();
int K=read(),cnt=0;
int l1=read(),r1=read();
int l2=read(),r2=read();
for(int i=1;i<=K;i++){
scanf("%s",T+1);
int x=T[1]-'a',y=T[2]-'a';
da[find(x)]=da[find(y)];
}
for(int i=0;i<26;i++){
(f[0][find(i)]+=get(i,l1,r1))%=Mod;
(f[1][find(i)]+=get(i,l2,r2))%=Mod;
}
for(int i=0;i<26;i++){
if(f[0][i]==f[1][i]) continue;
int ret=(f[0][i]-f[1][i])%Mod;
ret=(ret+Mod)%Mod;
if(!mp.count(ret)) return (void)puts("NO");
s[++cnt]=mp[ret];
}
if(!cnt) return (void)puts("YES");
if(cnt>2) return (void)puts("NO");
if(s[1]+s[2]==0) puts("YES");
else puts("NO");
} signed main(){
scanf("%s",S+1);
n=strlen(S+1);
for(int i=0;i<26;i++){
has[i][0]=1;
for(int j=1;j<=n;j++){
has[i][j]=(has[i][j-1]*P%Mod+(S[j]==('a'+i)))%Mod;
}
}
po[0]=1;
for(int i=1;i<=n;i++) po[i]=po[i-1]*P%Mod;
for(int i=0;i<=n;i++) mp[po[i]]=i+1,mp[Mod-po[i]]=-i-1;
t=read();
while(t--) solve();
return 0;
}

题解 [51nod1753] 相似子串的更多相关文章

  1. 【做题】51NOD1753 相似子串——哈希

    题意:两个字符串相似定义为: 1.两个字符串长度相等 2.两个字符串对应位置上至多有一个位置所对应的字符不相同 给定一个字符串\(s\),\(T\)次询问两个子串在给定的规则下是否相似.给定的规则指每 ...

  2. 【USACO 3.1】Contact(01子串按出现次数排序)

    题意:给你一个01字符串,将长度为a到b之间(包含a.b)的子串按照出现次数排序.注意输入输出格式 题解:01子串对应一个二进制,为了区别11和011这样的不同子串,我们把长度也记录下来,官方题解是在 ...

  3. Codeforces Round #352 (Div. 2) ABCD

    Problems     # Name     A Summer Camp standard input/output 1 s, 256 MB    x3197 B Different is Good ...

  4. 【po3693】Maximum repetition substring

    题意: 给定一个字符串 求重复次数最多的连续重复子串 并输出字典序最小方案 题解: 枚举子串长度L 显然如果重复次数>1 那么答案串肯定包含s[1],s[1+L],s[1+L*2],...中的两 ...

  5. Zero Sum Subarray

    Given an integer array, find a subarray where the sum of numbers is zero. Your code should return th ...

  6. 【BZOJ3544】[ONTAK2010]Creative Accounting 前缀和+set

    [BZOJ3544][ONTAK2010]Creative Accounting Description 给定一个长度为N的数组a和M,求一个区间[l,r],使得(\sum_{i=l}^{r}{a_i ...

  7. Hdu-6230 2017CCPC-哈尔滨站 A.Palindrome Manacher 主席树

    题面 题意:给你一个字符串,问你满足s[i]=s[2n-i]=s[2n+i-2]的子串(这子串长度为3n-2)有多少个,原字符串长度<=5e5 题解:对于这种子串,其实要满足2个回文,跑过一次M ...

  8. Vijos1425子串清除 题解

    Vijos1425子串清除 题解   描述: 我们定义字符串A是字符串B的子串当且仅当我们能在B串中找到A串.现在给你一个字符串A,和另外一个字符串B,要你每次从B串中从左至右找第一个A串,并从B串中 ...

  9. 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)

    目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...

随机推荐

  1. Java多线程系列--AQS之 LockSupport

    concurrent包是基于AQS (AbstractQueuedSynchronizer)框架的,AQS(JAVA CAS原理.unsafe.AQS)框架借助于两个类: Unsafe(提供CAS操作 ...

  2. nginx location 路由的几个配置纪要

    1:网上没有查到在线测试 nginx location 规则的网址 在服务器上可以通过 return 返回测试比如  把#号去掉 # location /admin\.php(.*) # { #def ...

  3. Reids原理之IO模型

    众所周知Redis是单进程单线程的应用,在如今多核横行的时代,我们不免有疑问,单线程的redis怎么就成了高性能的代表 当有多个线程同时调用redis的时候,那么单线程的redis是怎么处理的呢,这里 ...

  4. CF197A Plate Game

    题目描述 你有一个长方形的桌子,长度 a ,宽度 b ,以及无限多的半径 r的圆盘. 两位玩家玩以下游戏:他们轮流把圆盘放在桌子上,使得盘子之间不能互相重叠(但他们的边缘可以互相接触),任何盘子上的任 ...

  5. 【MIT 6.824 】分布式系统 课程笔记(二)Lecture 03 : GFS

    Lecture 03 : GFS 一.一致性 1, 弱一致性 可能会读到旧数据 2, 强一致性 读到的数据都是最新的 3, 一致性比较 强一致性对于app的写方便, 但是性能差 弱一致性有良好的性能, ...

  6. 使用keepalived实现kubenetes apiserver高可用

    # 安装 nginx yum install nginx -y # 配置nginx4层代理 /etc/nginx/nginx.conf stream { upstream kube-apiserver ...

  7. axios 发 post 请求,后端接收不到参数的解决方案(转载)

    原文地址:https://www.cnblogs.com/yiyi17/p/9409249.html 问题场景 场景很简单,就是一个正常 axios post 请求: axios({ headers: ...

  8. springcloud源码解析(目录)

    springcloud是一个基于springboot的一站式企业级分布式应用开发框架.springboot为其提供了创建单一项目的便利性,springcloud组合了现有的.常用的分布式项目的解决方案 ...

  9. springboot下@webfilter的使用

    启动类加了@ServletComponentScan,无论过滤器类加不加@Componment urlPatterns = {"/test/*"}都可以生效 单使用@Compone ...

  10. 无限重启:windows更新之后,在输入密码页面无限重启进入不了系统

    解决办法:windows更新之后,在输入密码页面无限重启 总体思路:进入安全模式(如何进入,下文将讲述)  -->   点击疑难解答   -->   点击高级选项  -->  点击启 ...