description

wyl8899今天也很刻苦的在做老师布置下来的题目!

这一天老师布置的题目是这样的:

给出两个仅含小写字母的字符串A和B,输出最大的k,使得A[1..k]是B的子串。

A和B的长度都不会超过50000。

很显然他并不知道正确的做法,但是他居然卡着时间过掉了老师给的数据!

你找到了他提交给老师的程序,经过测试你惊讶的发现,他的程序运行时间恰好是最终答案,单位是毫秒。

你现在找到了老师给的数据中的一笔,你决定至多修改A串中的一个字母,使得他的程序尽可能的慢。

现在,你能告诉我修改数据之后他的程序在这个测试点的运行时间么?(单位当然还是毫秒)


analysis

  • 有一种比较好想的方法是二分$+$字符串哈希

  • 搞完两个串的哈希后,枚举母串的开始位置$i$

  • 然后第一个二分找出从$B$的第$i$位开始的最长一段相同串的长度

  • 第二个二分跳过中间不相同的点,再二分找出接下来的最长一段相同串,更新答案

  • 注意中间有不少判断,比如判$A$串匹配完了或$B$串剩下位数不够匹配等等


code

#pragma GCC optimize("O3")
#pragma G++ optimize("O3")
#include<stdio.h>
#include<string.h>
#include<algorithm>
#define q 29
#define MAXN 50005
#define mod 1000000007
#define ll long long
#define fo(i,a,b) for (ll i=a;i<=b;++i)
#define fd(i,a,b) for (ll i=a;i>=b;--i) using namespace std; char st1[MAXN],st2[MAXN];
ll hash1[MAXN],hash2[MAXN],mi[MAXN];
ll len1,len2,ans; inline ll max(ll x,ll y){return x>y?x:y;}
inline ll get_hash1(ll x,ll y){return ((hash1[y]-hash1[x-1]*mi[y-x+1])%mod+mod)%mod;}
inline ll get_hash2(ll x,ll y){return ((hash2[y]-hash2[x-1]*mi[y-x+1])%mod+mod)%mod;}
int main()
{
scanf("%s%s",st1+1,st2+1);
len1=strlen(st1+1),len2=strlen(st2+1),mi[0]=1;
fo(i,1,len1)hash1[i]=(hash1[i-1]*q+st1[i]-'a')%mod;
fo(i,1,len2)hash2[i]=(hash2[i-1]*q+st2[i]-'a')%mod;
fo(i,1,len2)mi[i]=mi[i-1]*q%mod;
fo(i,1,len2)
{
ll l=1,r=len1,mid=(l+r)>>1;
while (l<=r)
{
mid=(l+r)>>1;
if (i+mid-1>len2 || get_hash1(1,mid)!=get_hash2(i,i+mid-1))r=mid-1;
else l=mid+1;
}
ll next=r+2,tot=((i+r-1==len2 && r!=len1)?r:r+1),tmp=r;
l=1,r=len1-r-1,mid=(l+r)>>1;
while (l<=r)
{
mid=(l+r)>>1;
if (i+tmp+mid>len2 || get_hash1(next,next+mid-1)!=get_hash2(i+tmp+1,i+tmp+mid))r=mid-1;
else l=mid+1;
}
ans=max(ans,r+tot);
}
printf("%lld\n",ans);
return 0;
}

【JZOJ3337】wyl8899的TLE的更多相关文章

  1. [JZOJ3337] 【NOI2013模拟】wyl8899的TLE

    题目 题目大意 给你两个字符串\(A\)和\(B\),可以修改\(A\)中的一个字符,求修改后最长的\(A\)的前缀,使它是\(B\)的子串. 思考历程 看到这道题之后,第一眼想到的就是后缀自动机! ...

  2. 卫星轨道和两行数据TLE

    最近由于Sino-2和北斗的关系,很多网友贴了表示卫星运行轨道的TLE数据.这里想对卫星轨道参数和TLE的格式做一个简单介绍.虽然实际上没有人直接读TLE数据,而都是借助软件来获得卫星轨道和位置信息, ...

  3. hdu 3068 最长回文子串 TLE

    后缀数组+RMQ是O(nlogn)的,会TLE..... 标准解法好像是马拉车,O(n).... #include "algorithm" #include "cstdi ...

  4. POJ 2240 && ZOJ 1082 Arbitrage 最短路,c++ stl pass g++ tle 难度:0

    http://poj.org/problem?id=2240 用log化乘法为加法找正圈 c++ 110ms,g++tle #include <string> #include <m ...

  5. == Got TLE on OJ? Here is the solution! ==

    As a solo warrior in OJ, I spent about nearly 50% of my time on tackling TLE - that is innumerous ho ...

  6. SPOJ 274 Johnny and the Watermelon Plantation(TLE)

    O(n^3)的时间复杂度,改了半天交了二三十遍,TLE到死,实在没办法了…… 跪求指点!!! #include <cstdio> #include <cstdlib> #inc ...

  7. 转自他人——————TLE之前,没有一个节点叫失败!!!

    我想我十八年来记忆最深刻的夜晚,大概便是在吉林大学燥热的宿舍里,穿着橘黄色的短袖,努力咽下大口大口的雪碧.那天晚上我仰躺在吉大热得几乎不能入眠的床板上,一动不动,看夏夜里打不尽的蚊子在惨白的天花板下飞 ...

  8. 关于Java中Arrays.sort()方法TLE

    最近一直在练用Java写题,今天无意发现一道很简单的二分题(链接),我一开始是直接开int[]数组调用Arrays.sort()去排序,没想到TLE了,原来是因为jdk中对于int[]的排序是使用快速 ...

  9. 1833 深坑 TLE 求解

    题目描述: 大家知道,给出正整数n,则1到n这n个数可以构成n!种排列,把这些排列按照从小到大的顺序(字典顺序)列出,如n=3时,列出1 2 3,1 3 2,2 1 3,2 3 1,3 1 2,3 2 ...

随机推荐

  1. AsyncAwait

    using System; using System.Diagnostics; using System.Threading; using System.Threading.Tasks; namesp ...

  2. python中字典排序

    一.Python的排序 1.reversed() 这个很好理解,reversed英文意思就是:adj. 颠倒的:相反的:(判决等)撤销的 print list(reversed(['dream','a ...

  3. USACO2012 Broken necklace /// DP oj10103

    题目大意: 项链最长的纯色连续段,“w”即white白色珠子,可任意涂为红或蓝,“r” “b”即红 蓝. Input Line 1:  N, the number of beads Line 2:   ...

  4. sys_call_table HOOK

    sys_call_table 这个东西,其实和 Windows 下的 SSDT 表,在功能上完全相同. 前一阵子学Linux驱动,遇到了这个系统调用表,然后我就想到Windows的SSDT表,既然SS ...

  5. maven中报错Missing artifact com.oracle:ojdbc14:jar:10.2.0.4.0

    在检索完工程后报错Missing artifact com.oracle:ojdbc14:jar:10.2.0.4.0. 由于oracle的ojdbc收费,所以在maven项目导入时没有ojdbc14 ...

  6. JS对象 数组连接 concat() 方法用于连接两个或多个数组。此方法返回一个新数组,不改变原来的数组。 语法 arrayObject.concat(array1,array2,.arrayN)

    concat() 方法用于连接两个或多个数组.此方法返回一个新数组,不改变原来的数组. 语法 arrayObject.concat(array1,array2,...,arrayN) 参数说明: 注意 ...

  7. Sqlite多线程相关整理

    Sqlite多线程相关整理 Sqlite With MultiThreads 什么是线程安全? 当多个线程访问某个方法时,不管你通过怎样的调用方式.或者说这些线程如何交替地执行,我们在主程序中不需要去 ...

  8. All you need to know about: solder mask and paste mask

    1, 从字面理解 (1) 从字面理解,solder mask意指要mask住需要solder的地方.那么被mask的是谁呢?是绿油层.可以把默认形态的绿油层想象成与PCB板形状.面积相同,solder ...

  9. C++——虚析构

    目的: //只执行了 父类的析构函数//向通过父类指针 把 所有的子类对象的析构函数 都执行一遍//向通过父类指针 释放所有的子类资源 方法:在父类的析构函数前+virtual关键字 #define ...

  10. OBJC依赖库管理利器cocoapods 安装及使用详细图解

    cocoapods: github:https://github.com/CocoaPods/CocoaPods 官方网站:http://www.cocoapods.org/ 1.安装 RubyGem ...