COGS 902 乐曲主题 题解 & hash入门贺
【题意】
给定一个长为n的序列,元素都是不超过88的正整数,求序列中主题的最大长度。
所谓主题是指在序列中出现了至少两次并且不相交的子串。特别的,主题可以变调,也就是说如果一个子串全部加上或减去一个数后与另一个子串相同,那么也认为它们是相同的。
对于100%的数据,n<=5000。
【解法】
所谓的变调不过是升降趋势相同,直接来一发差分就好。
答案显然有单调性,长度越长主题越不容易出现,因此可以二分答案,每次只要查询长为ans的子串中是否存在相同且不相交的两个子串即可。
查询子串是否相同可以用哈希实现,这样只要O(n)预处理一发h数组并递推幂取模,取hash值就果断O(1)了。
关于hash的取模,可以直接用unsigned long long自动溢出取模(虽然这是最容易被卡的hash……)。
贴个代码(也不知道出了什么事儿,莫名的折叠不了了,垃圾cnblogs):
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
#define ULL unsigned long long
using namespace std;
const int maxn=;
const ULL T=173ull;
void init();
ULL hash(int,int);
ULL h[maxn],pw[maxn],tmp;
int n,a[maxn],L,R,M;
bool ok;
map<ULL,int>id;
int main(){
#define MINE
#ifdef MINE
freopen("theme.in","r",stdin);
freopen("theme.out","w",stdout);
#endif
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
for(int i=n;i;i--)a[i]-=a[i-];
init();
L=;R=n;
while(L<=R){
M=(L+R)>>;
ok=false;
for(int i=;i+M-<=n;i++){
tmp=hash(i,M);
if(id.count(tmp)){
if(id[tmp]<i-M){
ok=true;
break;
}
}
else id[tmp]=i;
}
if(ok)L=M+;
else R=M-;
}
if(L<)L=;
printf("%d",L);
#ifndef MINE
printf("\n-------------------------DONE-------------------------\n");
for(;;);
#endif
return ;
}
inline void init(){
for(int i=n;i;i--)h[i]=h[i+]*T+(a[i]+);
pw[]=1ull;
for(int i=;i<=n;i++)pw[i]=pw[i-]*T;
}
inline ULL hash(int x,int l){return h[x]-h[x+l]*pw[l];}
/*
30
25 27 30 34 39 45 52 60 69 79 69 60 52 45 39 34 30 26 22 18
82 78 74 70 66 67 64 60 65 80
Answer:
9
*/
【hash相关】
虽说是抄的蓝书的hash……但不管怎么说自己算是会写hash了……好感动……
如果字符串给定,询问的串都是它的子串,那么可以O(n)预处理,O(1)查询。
具体来说,定义后缀hash函数为
hi=Tn-i+1si+Tn-isi+1+……+sn,其中T代表字符集大小。
那么利用秦九韶大法,有如下递推式:
hi=hi+1*T+si
然后就可以happy的O(n)推出所有h值啦。
查询的时候,记以x开头,长为l的子串的hash值为hash(x,l),那么有
hash(x,l)=Tlsx+Tl-1sx+1+……+sx+l-1
由上面h函数的公式,可以推出
hash(x,l)=hx-Tlhx+l
然后就可以happy的O(1)查询啦。
COGS 902 乐曲主题 题解 & hash入门贺的更多相关文章
- 主题模型 LDA 入门
主题模型 LDA 入门(附 Python 代码) 一.主题模型 在文本挖掘领域,大量的数据都是非结构化的,很难从信息中直接获取相关和期望的信息,一种文本挖掘的方法:主题模型(Topic Model ...
- TYUT程序设计入门第四讲练习题题解--数论入门
程序设计入门第四讲练习题题解--数论入门 对于新知识点的学习,需要不断地刷题训练,才能有所收获,才能更好地消化知识点. 题组链接: 程序设计入门第四讲练习题--数论 by vjudge 题解: A. ...
- [USACO 5.1.3]乐曲主题
Description 我们用N(1 <= N <=5000)个音符的序列来表示一首乐曲,每个音符都是1..88范围内的整数,每个数表示钢琴上的一个键.很不幸这种表示旋律的方法忽略了音符的 ...
- hash入门
如果你已经确保自己的hash技巧已经入门,那么请左转这篇博文 首先介绍一下hash? 事实上是一种叫做蛤丝的病毒 以下讲到的hash都是OI中最常用到的hash方法:进制哈希 做法: 首先设一个进制数 ...
- poj1200-Crazy Search(hash入门经典)
Hash:一般是一个整数.就是说通过某种算法,可以把一个字符串"压缩" 成一个整数.一,题意: 给出两个数n,nc,并给出一个由nc种字符组成的字符串.求这个字符串中长度为n的不同 ...
- HDU 1880 字符串hash 入门题
Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一个需要的魔 ...
- 字符串hash入门
简单介绍一下字符串hash 相信大家对于hash都不陌生 翻译过来就是搞砸,乱搞的意思嘛 hash算法广泛应用于计算机的各类领域,像什么md5,文件效验,磁力链接 等等都会用到hash算法 在信息学奥 ...
- 洛谷P2743 乐曲主题Musical Themes [USACO5.1] SA
正解:SA 解题报告: 传送门 这题三个条件嘛,那就一个个考虑下都解决了就把这题解决了嘛QwQ 那就直接分别针对三个条件写下各个击破就欧克辣? 1)长度大于等于5:求出答案之后和5比大小 2)不能有公 ...
- [USACO5.1] 乐曲主题Musical Themes
题目链接:戳我 Emmm......hash怎么做啊不会啊 这里是SA后缀数组版本的 就是先两两做差分,作为要处理后缀的数组.普通地求出来h数组之后,我们二分这个答案,然后判定是否合法就行了.是否合法 ...
随机推荐
- JQM弹出对话框
<div data-role="page" id="pageone"> <div data-role="header"&g ...
- jquery特效收藏
js网址收藏: 懒人图库:www.lanrentuku.com 懒人之家:http://www.lanrenzhijia.com/jquery/list_5_2.html 1.UI下载:http:// ...
- 处理ecshp图片上传失真
默认生成jpg缩略图或商品图的质量是80,有些时候不够满意,现提供调整生成jpg图片的质量的方法找到includes/cls_image.php,在大约250行左右 /* 生成文件 */ ...
- tableview中在tableheaderView上放一个视图,第一次进入视图显示不正常,往下拉视图仍然不正常,往上拉视图正常
解决办法: frame来源不正常,从直接在viewDidLoad方法中设置的frame,改为 - (void)viewDidLayoutSubviews { [super viewDidLayoutS ...
- Python之路【第十一篇续】前端初识之CSS
css解释 css样式: css是英文Cascading Style Sheets的缩写,称为层叠样式表,用于对页面进行美化,CSS的可以使页面更加的美观.基本上所有的html页面都或多或少的使用cs ...
- Java多线程编程核心技术--定时器
Timer类主要负责计划任务,也就是在指定的时间开始执行某一个任务. 方法schedule(TimerTask task, Date time) public class Task { private ...
- redis使用watch完成秒杀抢购功能(转)
redis使用watch完成秒杀抢购功能: 使用redis中两个key完成秒杀抢购功能,mywatchkey用于存储抢购数量和mywatchlist用户存储抢购列表. 它的优点如下: 1. 首先选用内 ...
- 使用HttpFileServer自建下载服务器
如今单位办公离不开电脑,使用电脑离不开资料传输,举一个简单的例子吧,很多用户经常在电脑上编辑文件,这些文件往往打印出来给领导审阅,可是你电脑上没有打印机,这时你会想到通过优盘.网络硬盘.邮箱.QQ等方 ...
- 使用自己的ClassLoader实现热替换
首先实现一个自己的ClassLoader,该ClassLoader重写findClass方法. 从classpath中加载类资源. 注意,不要重写loadClass方法. 因为在使用自定义的MyCl ...
- [MongoDB]count,gourp,distinct
摘要 上篇文章介绍了CRUD的操作,会了这些,基本上可以完成很多工作了.但如果遇到统计类的操作,那么就需要学习下本篇的内容了. 相关文章 [MongoDB]入门操作 [MongoDB]增删改查 cou ...