【BZOJ4650&UOJ219】优秀的拆分(二分,hash)
题意:

思路:



在实现时SA可以用hash+二分代替,会多一个log
BZ上跑的飞快,但UOJ上extra卡出翔,已经放弃
不过转C或者写SA没准就过了
看来转C迫在眉睫
const mo=;
var f,g:array[..]of int64;
h,mi:array[..]of int64;
v,cas,i,n,j,x,y:longint;
ans:int64;
ch:ansistring; function min(x,y:longint):longint;
begin
if x<y then exit(x);
exit(y);
end; function hash(x,y:longint):longint;
begin
hash:=(h[y]-h[x-]*mi[y-x+] mod mo+mo) mod mo;
end; function lcp(x,y:longint):longint;
var l,r,mid,last:longint;
begin
l:=; r:=min(i,min(n-x+,n-y+)); last:=;
while l<=r do
begin
mid:=(l+r)>>;
if hash(x,x+mid-)=hash(y,y+mid-) then begin last:=mid; l:=mid+; end
else r:=mid-;
end;
exit(last);
end; function lcs(x,y:longint):longint;
var l,r,mid,last:longint;
begin
l:=; r:=min(i,min(x,y)); last:=;
while l<=r do
begin
mid:=(l+r)>>;
if hash(x-mid+,x)=hash(y-mid+,y) then begin last:=mid; l:=mid+; end
else r:=mid-;
end;
exit(last);
end; begin mi[]:=;
for i:= to do mi[i]:=mi[i-]* mod mo;
readln(cas);
for v:= to cas do
begin
readln(ch);
n:=length(ch);
for i:= to n+ do
begin
f[i]:=; g[i]:=; h[i]:=;
end;
for i:= to n do h[i]:=(h[i-]*+ord(ch[i])-ord('a')+) mod mo;
for i:= to (n+) div do
begin
j:=;
while j<=n do
begin
if j+i>n then break;
if (ch[j]<>ch[j+i]) then begin j:=j+i; continue; end;
x:=lcp(j,j+i); y:=lcs(j,j+i);
// x:=min(x,i); y:=min(y,i);
if x+y>i then
begin
inc(g[j-y+]); dec(g[j+x-i+]);
inc(f[j+i-y+i]); dec(f[j+i+x]);
end;
j:=j+i;
end;
end;
ans:=;
for i:= to n do f[i]:=f[i-]+f[i];
for i:= to n do g[i]:=g[i-]+g[i];
for i:= to n- do ans:=ans+f[i]*g[i+];
writeln(ans);
end; end.
【BZOJ4650&UOJ219】优秀的拆分(二分,hash)的更多相关文章
- [UOJ#219][BZOJ4650][Noi2016]优秀的拆分
[UOJ#219][BZOJ4650][Noi2016]优秀的拆分 试题描述 如果一个字符串可以被拆分为 AABBAABB 的形式,其中 A 和 B 是任意非空字符串,则我们称该字符串的这种拆分是优秀 ...
- 洛谷P1117 优秀的拆分【Hash】【字符串】【二分】【好难不会】
题目描述 如果一个字符串可以被拆分为AABBAABB的形式,其中 A和 B是任意非空字符串,则我们称该字符串的这种拆分是优秀的. 例如,对于字符串aabaabaaaabaabaa,如果令 A=aabA ...
- UOJ219 NOI2016 优秀的拆分 二分、字符串哈希
传送门 题目可以转化为求\(AA\)的数量,设\(cnt1_x\)表示左端点为\(x\)的\(AA\)的数量,\(cnt2_x\)表示右端点为\(x\)的\(AA\)的数量,那么答案就是\(\sum ...
- BZOJ4650 [NOI2016]优秀的拆分 【后缀数组】
题目 如果一个字符串可以被拆分为 AABBAABB 的形式,其中 AA 和 BB 是任意非空字符串,则我们称该字符串的这种拆 分是优秀的.例如,对于字符串 aabaabaa,如果令 A=aabA=aa ...
- BZOJ4650: [Noi2016]优秀的拆分(hash 调和级数)
题意 题目链接 Sol NOI的题都这么良心么.. 先交个\(n^4\)暴力 => 75 hash优化一下 => 90 然后\(90\)到\(100\)分之间至少差了\(10\)难度台阶= ...
- bzoj4650: [Noi2016]优秀的拆分 hash
好气啊,没开longlong又biubiu了 底层: 用hash或者奇奇怪怪的算法兹磁logn求最长公共前后缀 思路: 统计出从一个点开始和结束的形如AA的子串的个数 统计的时候把相邻的结果相乘加起来 ...
- UOJ#219/BZOJ4650 [NOI2016]优秀的拆分 字符串 SA ST表
原文链接http://www.cnblogs.com/zhouzhendong/p/9025092.html 题目传送门 - UOJ#219 (推荐,题面清晰) 题目传送门 - BZOJ4650 题意 ...
- BZOJ4650: [Noi2016]优秀的拆分
考场上没秒的话多拿5分并不划算的样子. 思想其实很简单嘛. 要统计答案,求以每个位置开始和结束的AA串数量就好了.那么枚举AA中A的长度L,每L个字符设一个关键点,这样AA一定经过相邻的两个关键点.计 ...
- BZOJ4650 NOI2016优秀的拆分(后缀数组)
显然只要求出以每个位置开始的AA串数量就可以了,将其和反串同位置的结果乘一下,加起来就是答案.考虑对每种长度的字符串计数.若当前考虑的A串长度为x,我们每隔x个字符设一个关键点,求出相邻两关键点的后缀 ...
- [BZOJ4650][NOI2016]优秀的拆分(SAM构建SA)
关于解法这个讲的很清楚了,主要用了设关键点的巧妙思想. 主要想说的是一个刚学的方法:通过后缀自动机建立后缀树,再转成后缀数组. 后缀数组功能强大,但是最令人头疼的地方是模板太难背容易写错.用这个方法, ...
随机推荐
- idea下载安装指南
官网地址 https://www.jetbrains.com/idea/ 点击download 有收费版本和社区免费版.我下载了免费的. 有zip和exe两个版本.我先下载了zip绿色版,发现用不了. ...
- ACM_Scramble Sort
Scramble Sort Time Limit: 2000/1000ms (Java/Others) Problem Description: In this problem you will be ...
- 简单的win7-cmd命令提示符
在win7打开cmd窗口 有两个路径:(1)开始 -->所有程序 --> 附件 --> 命令提示 (2)开始 -->在搜索框输入 “cmd” 指令 作用 对文件夹的操作 ...
- 微信小程序授权 获取用户的openid和session_key【后端使用java语言编写】,我写的是get方式,目的是测试能否获取到微信服务器中的数据,后期我会写上post请求方式。
在这里给大家分享下我的心得,1.写代码前一定要对整个流程有个了解.我就是因为在先不了解整个过程中去ctrl+c+v他人的博客代码,花费很多无用的时间去处理还不知道能不能跑的起来的代码. 2.本人比较喜 ...
- document.write清除原有内容情况
原博客: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta ...
- Selenium示例集锦--常见元素识别方法、下拉框、文本域及富文本框、鼠标操作、一组元素定位、弹窗、多窗口处理、JS、frame、文件上传和下载
元素定位及其他操作 0.常见的识别元素的方法是什么? driver.find_element_by_id() driver.find_element_by_name() driver.find_ele ...
- 微信小程序组件解读和分析:三、swiper滑块视图
swiper滑块组件说明: 滑块视图容器,用于展示图片,可以通过用户拖拽和设置自动切换属性控制图片的切换 组件的使用示例的运行效果如下: 下面是WXML代码: [XML] 纯文本查看 复制代码 ? ...
- Jmeter之JDBC请求参数化(一)
一.环境准备 a.jmeter5.1.1版本最新版本,可以去网页下载:https://jmeter.apache.org/download_jmeter.cgi b.jdbc驱动:链接:https:/ ...
- 梦想CAD控件文字COM接口知识点
一.参数绘制文字 在CAD设计时,需要绘制文字,用户可以设置设置绘制文字的高度等属性. 主要用到函数说明: _DMxDrawX::DrawText 绘制一个单行文字.详细说明如下: 参数 说明 DOU ...
- vue+axios上传文件
单独上传文件: <input class="file" name="file" type="file" accept="im ...