Contest 20140914 Mushroom写情书 字符串雙hash 後綴數組
0111:Mushroom写情书
- 总时间限制:
- 10000ms
- 内存限制:
- 256000kB
- 描述
-
有一天,Mushroom准备向他的GF表白,为了增加表白成功率,Mushroom写了封情书寄给他的GF(记为S1),而他的GF也回寄了一封(记为S2)。现在,Mushroom想知道,这两封信的最长公共子串是多少。
- 输入
- 两行仅包含小写字母的字符串(S1,S2)。
- 输出
- 当不存在公共字符串时,输出一行0,。否则先输出一行表示最长公共子串,再输出最长公共子串的长度,如果有多个解满足,输出首先在S2中出现的(详见样例)
- 样例输入
-
abcdef
defabc - 样例输出
-
def
3 // abc和def都在S1和S2中出现过,由于def在S2中先出现,所以输出def - 提示
- 对于30%的数据,1<=|S2|<=|S2|<=100
对于60%的数据,1<=|S2|<=|S2|<=1000
对于100%的数据,1<=|S2|<=|S2|<=250000 - 来源
- mushroom
- 在做這道題之前還重來沒有編過雙hash,這次算是找了一下感覺,反正自己覺得雙hash非常容易些錯,所以以後要多加小心。
- 考場上我用的後綴數組,由於題目中要求優先在s2中出現,所以後綴數組顯得非常麻煩。
-
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<ctime>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<string>
#include<queue>
#include<stack>
using namespace std;
#ifdef WIN32
#define LL "%I64d"
#else
#define LL "%lld"
#endif
#define MAXN 251000
#define MAXM 251000
#define MAXE MAXN
#define VAL1 100007
#define VAL2 1000007
#define PROB "letter"
typedef long long qword;
const qword mod=;
const qword _a=;
qword hs1[MAXN],hs2[MAXN];
qword pow_mod(qword a,int x)
{
qword ret=;
while (x)
{
if (x&)ret=ret*a%mod;
a=a*a%mod;
x>>=;
}
return ret;
} inline qword hash1(int x,int y)
{
return ((hs1[y]-hs1[x-]*pow_mod(_a,y-x+))%mod+mod)%mod;
}
inline qword hash2(int x,int y)
{
return ((hs2[y]-hs2[x-]*pow_mod(_a,y-x+))%mod+mod)%mod;
} /*
struct aaa
{
short s[MAXN];
char ss[MAXN];
int v[MAXN];
void Init(char *_ss)
{
strcpy(ss,_ss);
n=strlen(ss);
m=n;
int i;
for (i=0;i<n;i++)
{
s[i]=ss[i]-'a'+2;
}
v[0]=1;
for (i=1;i<n;i++)
{
v[i]=(v[i-1]*_a+s[i])%mod;
}
}
};*/
struct Edge
{
int pos;
Edge *next;
}E[MAXE],*V1[VAL1],*V2[VAL2];
int tope=-;
void addedge(Edge **V,int x,int y)
{
E[++tope].pos=y;
E[tope].next=V[x];
V[x]=&E[tope];
}
bool cross(Edge *ne1,Edge *ne2)
{
Edge *ne3,*ne4;
for (ne3=ne1;ne3;ne3=ne3->next)
{
for (ne4=ne2;ne4;ne4=ne4->next)
{
if (ne3->pos==ne4->pos)return true;
}
}
return false;
}
char str[][MAXN];
int main()
{
freopen(PROB".in","r",stdin);
freopen(PROB".out","w",stdout);
//freopen(PROB".out","w",stdout);
int i,j,k;
int x,y,z;
scanf("%s\n%s",str[]+,str[]+);
int n=strlen(str[]+),m=strlen(str[]+);
int l=,r=min(n,m)+;
int mid;
hs1[]=hs2[]=;
for (i=;i<=n;i++)
hs1[i]=((qword)hs1[i-]*_a%mod+str[][i]-'a'+)%mod;
for (i=;i<=m;i++)
hs2[i]=((qword)hs2[i-]*_a%mod+str[][i]-'a'+)%mod;
//cout<<hash1(1,2)<<endl;;
bool flag;
int ansp;
while (l+<r)
{
memset(V1,,sizeof(V1));
memset(V2,,sizeof(V2));
flag=false;
mid=(l+r)>>;
tope=-;
// mid=8;
for (i=;i+mid-<=n;i++)
{
y=i+mid-;
x=i;
z=hash1(x,y);
addedge(V1,z%VAL1,x);
addedge(V2,z%VAL2,x);
// cout<<z<<endl;
}
for (i=;i+mid-<=m;i++)
{
y=i+mid-;
x=i;
z=hash2(x,y);
if (V1[z%VAL1] && V2[z%VAL2] && cross(V1[z%VAL1],V2[z%VAL2]))
{
flag=true;
ansp=i;
break;
}
// cout<<"#"<<z<<endl;
}
if (flag)
l=mid;
else
r=mid;
}
str[][l+ansp]=;
printf("%s\n%d\n",str[]+ansp,l);
return ;
}
Contest 20140914 Mushroom写情书 字符串雙hash 後綴數組的更多相关文章
- 【BZOJ3796】Mushroom追妹纸 二分+hash
[BZOJ3796]Mushroom追妹纸 Description Mushroom最近看上了一个漂亮妹纸.他选择一种非常经典的手段来表达自己的心意——写情书.考虑到自己的表达能力,Mushroom决 ...
- redis 2 字符串 和 hash
string是最简单的类型,一个key对应一个value,string类型是二进制安全的.redis的string可以包含任何数据,比如JPG图片或者序列化的对象 操作 set 设置key ...
- 写出将字符串中的数字转换为整型的方法,如:“as31d2v”->312,并写出相应的单元测试,正则去掉非数值、小数点及正负号外的字符串
写出将字符串中的数字转换为整型的方法,如:"as31d2v"->312,并写出相应的单元测试,输入超过int范围时提示不合法输入. public struct Convert ...
- 【转载】一步一步写算法(之hash表)
转载自:http://blog.csdn.net/feixiaoxing/article/details/6885657 [ 声明:版权所有,欢迎转载,请勿用于商业用途. 联系信箱:feixiaox ...
- 一步一步写算法(之hash表)
[ 声明:版权全部,欢迎转载,请勿用于商业用途. 联系信箱:feixiaoxing @163.com] hash表,有时候也被称为散列表.个人觉得,hash表是介于链表和二叉树之间的一种中间结构.链 ...
- mycat1.6.5分片(字符串拆分hash)
https://blog.csdn.net/webnum/article/details/78313525 分片规则:字符串拆分hash 一.conf/schema.xml文件 <?xm ...
- 用Python分析下王小波与李银河写情书最爱用哪些词
作家王小波其实也是我国最早期的程序员,突发奇想,王小波写情书最喜欢用哪些词呢?用Python词云分析下! 直接上代码吧,有注释很好理解.输出的图片设置的比较大,所以运行的比较慢,可以适当把图片尺寸改小 ...
- js字符串轉數組,數組轉字符串
字符串轉數組:split(',') 數組轉字符串:join(‘,’) https://www.cnblogs.com/woodk/p/5714329.html
- 学习hash_map从而了解如何写stl里面的hash函数和equal或者compare函数
---恢复内容开始--- 看到同事用unordered_map了所以找个帖子学习学习 http://blog.sina.com.cn/s/blog_4c98b9600100audq.html (一)为 ...
随机推荐
- 假设但是学习java入门,请离开SSH稍远
我觉得有点累了步行上班,我想买一辆自行车.结果去了一看,想2500片.旁边的人说,2500所有最好加一些钱,买一挖电. 遂问电动车价格,3500,决定买.却被告知不如加点钱买小踏板摩托划算.于是看摩托 ...
- mybatis05 用户添加
User.xml 向用户表插入一条记录. 主键返回 需求:user对象插入到数据库后,新记录的主键要通过user对象返回,这样就可以通过user获取主键值. 解决思路: 通过LAST_INSERT_I ...
- careercup-数组和字符串1.7
1.7 编写一个算法,若M*N矩阵中某个元素为0,则将其所在的行与列清零. 类似于leetcode中的 Set Matrix Zeroes C++实现代码: #include<iostream& ...
- 初步掌握HBase
1.HBase概述 HBase是hadoop生态系统中的重要组成部分,是一个开源的.面向列.适合存储海量非结构化数据或半结构化数据,具备高可靠性.高性能.可灵活扩展伸缩.支持实时数据读写的分布式存储系 ...
- 使用 JSSE 定制 SSL 连接的属性--转载
当数据在网络上传播的时候,通过使用 SSL 对其进行加密和保护,JSSE 为 Java 应用程序提供了安全的通信.在本篇有关该技术的高级研究中,Java 中间件开发人员 Ian Parkinson 深 ...
- PureMVC(JS版)源码解析(二):Notification类
上篇博客,我们已经就PureMVC的设计模式进行的分析,这篇博文主要分析Notification(消息)类的实现. 通过Notification的构造函数可以看出,PureMVC中的Notificat ...
- FAQs: 我们可以在那里来为我的没有提升管理权限的应用程序存储用户数据?
如果你正在写一个不需要管理员权限的应用程序,如写一个业务线应用(Line of Business,LOB),用户应用程序如游戏,你总是要把应用程序的数据写到一个标准用可以访问的目录.下面列出一些所推荐 ...
- Eclipse - 添加 PyDev 插件
1. 安装PyDev插件 启用Eclipse.在Help菜单中,选择Install New Software···, 然后点击Add按钮.在Location中输入:http://pydev.org/u ...
- 关于js当中一些糟糕的特性
首先,不可否认,js是一门具有许多优秀特性的弱类型语言,但是这门语言在设计之初就投入了工程实践,没有经历严格的实验室测试,以致力于它是如此的粗糙,在相当长的一段时间很不受开发者待见,被视为一门玩具性的 ...
- 定位 position
html结构是fixed包裹relative,relative包裹absolute position:relative;相对定位 a 不影响元素本身的特性 b 不使元素脱离文档流(元素移动之后原始位置 ...