砂金听说了你在学字符串,于是在CLOI里出了道题给你


P3667 Bovine Genomics

题链:洛谷 hzoi提高

\(hash\)基础题。

思路是二分答案,\(check\)中比较每一个区间字串的\(hash\)值是否相等。

比较的时候可以用\(set\)或\(map\)。

\(set\)的好处在于无重元素,判断时先将\(a\)串中区间子串的哈希值放入数组,再用\(find\)函数,每次寻找\(b\)串的区间子串的哈希值是否出现过。我个人用的\(set\),代码在下面。

\(map\)的话写起来差不多,值类型设为\(bool\),每次直接判断\(true\,or\,false\)即可。

代码如下:

map<ull,bool>m;
bool check(int len)
{
int re=0;
for(int i=1;i+len-1<=m;i++)
{
bool kk=false;
m.clear();
int j=i+len-1;
fo(k,1,n)
m[Aget_hash(i,j,k,1)]=true;
fo(k,1,n)
if(m[Aget_hash(i,j,k,0)])
{
kk=true;
break;
}
if(!kk)
{
re=1;
break;
}
}
return re;
}

完整代码:

所有
#include<bits/stdc++.h>
#define fo(x,y,z) for(register int (x)=(y);(x)<=(z);(x)++)
#define fu(x,y,z) for(register int (x)=(y);(x)>=(z);(x)--)
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
namespace Dr
{
inline int qr()
{
char ch=getchar();int x=0,f=1;
for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
for(;ch>='0'&&ch<='9';ch=getchar())x=(x<<3)+(x<<1)+(ch^48);
return x*f;
}
inline void qw(ull x)
{
if(!x)
return;
qw(x/10);
putchar(x%10+'0');
}
}
#define qr qr()
using namespace Dr;
const int Ratio=0;
const int N=1005;
const int maxi=INT_MAX;
int lena,lenb,n,m;
ull p[N],ha[N][N],hb[N][N];
char a[N][N],b[N][N];
ull base=233,ans;
namespace Acheronhash
{
void Aprepare()
{
p[0]=1;
fo(i,1,500)
p[i]=p[i-1]*base;
}
ull Aget_hash(int l,int r,int id,int x)
{
if(x)
return ha[id][r]-ha[id][l-1]*p[r-l+1];
else
return hb[id][r]-hb[id][l-1]*p[r-l+1];
}
// ull Aget_s(int l,int r,int x)
// {
// return Aget_hash(l,x-1)*p[r-x]+Aget_hash(x+1,r);
// }
ull Aget_hashall(char c[])
{
int len=strlen(c);
ull ans=0;
fo(i,0,len-1)
ans=ans*base+(ull)c[i];
return ans;
}
void Aget_hasheverya(int id)
{
fo(i,1,m)
ha[id][i]=ha[id][i-1]*base+a[id][i];
}
void Aget_hasheveryb(int id)
{
fo(i,1,m)
hb[id][i]=hb[id][i-1]*base+b[id][i];
}
}
using namespace Acheronhash;
set<ull>f;
bool check(int len)
{
int re=0;
for(int i=1;i+len-1<=m;i++)
{
bool kk=false;
f.clear();
int j=i+len-1;
fo(k,1,n)
f.insert(Aget_hash(i,j,k,1));
fo(k,1,n)
if(f.find(Aget_hash(i,j,k,0))!=f.end())
{
kk=true;
break;
}
if(!kk)
{
re=1;
break;
}
}
return re;
}
int main()
{
Aprepare();
n=qr,m=qr;
fo(i,1,n)
{
scanf("%s",a[i]+1);
Aget_hasheverya(i);
}
fo(i,1,n)
{
scanf("%s",b[i]+1);
Aget_hasheveryb(i);
}
int l=1,r=m;
while(l<=r)
{
int mid=(l+r)>>1;
if(check(mid))
ans=mid,r=mid-1;
else
l=mid+1;
}
printf("%lld\n",ans);
return Ratio;
}
或一无所有


完结撒花

P3667 Bovine Genomics Hash+二分题解的更多相关文章

  1. 洛谷 [USACO17OPEN]Bovine Genomics G奶牛基因组(金) ———— 1道骗人的二分+trie树(其实是差分算法)

    题目 :Bovine Genomics G奶牛基因组 传送门: 洛谷P3667 题目描述 Farmer John owns NN cows with spots and NN cows without ...

  2. 【BZOJ】1014: [JSOI2008]火星人prefix(splay+hash+二分+lcp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1014 题意:支持插入一个字符.修改一个字符,查询lcp.(总长度<=100000, 操作< ...

  3. 【bzoj1014】[JSOI2008]火星人prefix Splay+Hash+二分

    题目描述 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 7 8 9 10 ...

  4. LOJ#6387 「THUPC2018」绿绿与串串 / String (Manacher || hash+二分)

    题目描述 绿绿和 Yazid 是好朋友.他们在一起做串串游戏. 我们定义翻转的操作:把一个串以最后一个字符作对称轴进行翻转复制.形式化地描述就是,如果他翻转的串为 RRR,那么他会将前 ∣R∣−1个字 ...

  5. POJ 1743 Musical Theme (字符串HASH+二分)

    Musical Theme Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 15900   Accepted: 5494 De ...

  6. Codeforces 1090J $kmp+hash+$二分

    题意 给出两个字符串\(s\)和\(t\),设\(S\)为\(s\)的任意一个非空前缀,\(T\)为\(t\)的任意一个非空前缀,问\(S+T\)有多少种不同的可能. Solution 看了一圈,感觉 ...

  7. bzoj1014: [JSOI2008]火星人prefix(splay+hash+二分)

    题目大意:一个字符串三个操作:①求两个后缀的LCP②插入一个字符③修改一个字符. 前几天刚学了hash+二分求lcp,就看到这题. 原来splay还能这么用?!原来splay模板这么好写?我以前写的s ...

  8. bnuoj 34990(后缀数组 或 hash+二分)

    后缀数组倍增算法超时,听说用3DC可以勉强过,不愿写了,直接用hash+二分求出log(n)的时间查询两个字符串之间的任意两个位置的最长前缀. 我自己在想hash的时候一直在考虑hash成数值时MOD ...

  9. 洛谷 P3670 [USACO17OPEN]Bovine Genomics S奶牛基因组(银)

    P3670 [USACO17OPEN]Bovine Genomics S奶牛基因组(银) 题目描述 Farmer John owns NN cows with spots and NN cows wi ...

  10. 140. 后缀数组(hash + 二分 / 后缀数组)

    题目链接 : https://www.acwing.com/problem/content/description/142/ Hash + 二分 #include <bits/stdc++.h& ...

随机推荐

  1. #KMP,容斥,dp#洛谷 5770 [JSOI2016] 无界单词

    题目传送门 分析 显然如果存在长度大于一半的border那么必然存在小于一半的 border,所以容斥一下, 设 \(dp[i]\) 表示长度为 \(i\) 的不存在公共前后缀的字符串个数,那么 \( ...

  2. #Tarjan#洛谷 5676 [GZOI2017]小z玩游戏

    题目 分析 可能玩两次也就是形成环即是Tarjan缩点后在同一个强连通分量 如果按照游戏连边数量将达到\(O(n^2)\),当中其实有很多边可以共用, 考虑\(i\)连向\(i\)的倍数,以及有趣程度 ...

  3. 批量拉取/git pull 指定文件夹下面所有 Git 项目的最新代码

    背景 因为工作需要,当前所负责的项目较多:但是人力紧缺,其中绝大部分项目平时也不会去跟进迭代.所以经常需要批量拉取最新的代码查看最新的改动. 解决方案 一键批量拉取指定文件夹下所有 Git 项目的最新 ...

  4. C#.Net WinForm学习笔记

    .Net WinForm学习笔记 1,MDI窗体设有两个窗体frmMain,frmChild,则:frmMain:  设IsMdiContainer属性为true 打开子窗口:  在相关事件中写如下代 ...

  5. Spring源码 20 手写模拟

    项目地址 https://gitee.com/liao-hang/hand-write-spring.git 模拟 Spring 注解 自动装配 Autowired @Target(ElementTy ...

  6. 标签栏切换效果 JS

    标签栏切换效果 JS 要求:class为tab-box的元素用于实现标签栏的外边框,,分别实现标签栏的标签部分和内容部分. html <div class="tab-box" ...

  7. 打造美团外卖新体验,HarmonyOS SDK 持续赋能开发者共赢鸿蒙生态

    从今年 8 月起,所有升级到 HarmonyOS 4 的手机用户在美团外卖下单后,可通过屏幕上的一个"小窗口",随时追踪到"出餐.取餐.送达"等订单状态.这个能 ...

  8. 从ID3到LGB

    梳理一下树模型算法,从三种最基础的tree到lgb的全过程笔记 基于信息增益(Information Gain)的ID3算法 ID3算法的核心是在数据集上应用信息增益准则来进行特征选择,以此递归的构建 ...

  9. DDD领域驱动设计总结和C#代码示例

    DDD(领域驱动设计)是一种软件设计方法,它强调以业务领域为核心来驱动软件的设计和开发. DDD 的设计初衷是为了解决复杂业务领域的设计和开发问题,它提供了一套丰富的概念和模式,帮助开发者更好地理解和 ...

  10. 力扣977(Java)-有序数组的平方(简单)

    题目: 给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序. 示例 1: 输入:nums = [-4,-1,0,3,10]输出:[0,1, ...