题意:

翻转是指其中一段长度为k的子串全部翻转

n<=200000 a[i]<=n

思路:枚举k,直接哈希判充即可

时间复杂度是n/i求和,根据定理可得是O(n log n)级别的

单哈双哈都可能被卡,我用的是单哈+哈希表判重

 const mo=;
var h1,h2,mi,c,a,head,vet,next:array[..]of longint;
n,i,p,j,st,ed,t1,t2,t3,l,ans,tot:longint; function hash1(x,y:longint):longint;
begin
hash1:=(h1[y]-int64(h1[x-])*mi[y-x+] mod mo) mod mo;
hash1:=(hash1+mo) mod mo;
end; function hash2(x,y:longint):longint;
begin
hash2:=(h2[y]-int64(h2[x-])*mi[y-x+] mod mo) mod mo;
hash2:=(hash2+mo) mod mo;
end; procedure swap(var x,y:longint);
var t:longint;
begin
t:=x; x:=y; y:=t;
end; procedure add(a,b:longint);
begin
inc(tot);
next[tot]:=head[a];
vet[tot]:=b;
head[a]:=tot;
end; function judge(u,x:longint):boolean;
var e,v:longint;
begin
e:=head[u];
while e<> do
begin
v:=vet[e];
if v=x then exit(false);
e:=next[e];
end;
exit(true);
end; begin
assign(input,'bzoj2081.in'); reset(input);
assign(output,'bzoj2081.out'); rewrite(output);
readln(n);
for i:= to n do read(a[i]);
mi[]:=;
for i:= to n do mi[i]:=int64(mi[i-])* mod mo;
for i:= to n do h1[i]:=(int64(h1[i-])*+a[i]) mod mo;
for i:= to n div do swap(a[i],a[n-i+]);
for i:= to n do h2[i]:=(int64(h2[i-])*+a[i]) mod mo;
for i:= to n do
begin
p:=; tot:=;
for j:= to n div i do
begin
st:=i*(j-)+; ed:=i*j;
t1:=hash1(st,ed); t2:=hash2(n-ed+,n-st+);
t3:=int64(t1)*t2 mod mo;
inc(t3); inc(t1); inc(t2);
if judge(t3,t1) then
begin
inc(p);
add(t3,t1);
add(t3,t2);
end;
end;
if p=ans then begin inc(l); c[l]:=i; end;
if p>ans then
begin
l:=; c[]:=i; ans:=p;
end;
for j:= to n div i do
begin
st:=i*(j-)+; ed:=i*j;
t1:=hash1(st,ed); t2:=hash2(n-ed+,n-st+);
t3:=int64(t1)*t2 mod mo;
inc(t3);
head[t3]:=;
end;
end;
writeln(ans,' ',l);
for i:= to l- do write(c[i],' ');
write(c[l]);
close(input);
close(output);
end.

【BZOJ2081】Beads(哈希表)的更多相关文章

  1. [PHP内核探索]PHP中的哈希表

    在PHP内核中,其中一个很重要的数据结构就是HashTable.我们常用的数组,在内核中就是用HashTable来实现.那么,PHP的HashTable是怎么实现的呢?最近在看HashTable的数据 ...

  2. Java 哈希表运用-LeetCode 1 Two Sum

    Given an array of integers, find two numbers such that they add up to a specific target number. The ...

  3. ELF Format 笔记(十五)—— 符号哈希表

    ilocker:关注 Android 安全(新手) QQ: 2597294287 符号哈希表用于支援符号表的访问,能够提高符号搜索速度. 下表用于解释该哈希表的组织,但该格式并不属于 ELF 规范. ...

  4. Java基础知识笔记(一:修饰词、向量、哈希表)

    一.Java语言的特点(养成经常查看Java在线帮助文档的习惯) (1)简单性:Java语言是在C和C++计算机语言的基础上进行简化和改进的一种新型计算机语言.它去掉了C和C++最难正确应用的指针和最 ...

  5. 什么叫哈希表(Hash Table)

    散列表(也叫哈希表),是根据关键码值直接进行访问的数据结构,也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个映射函数叫做散列函数,存放记录的数组叫做散列表. - 数据结构 ...

  6. 【哈希表】CodeVs1230元素查找

    一.写在前面 哈希表(Hash Table),又称散列表,是一种可以快速处理插入和查询操作的数据结构.哈希表体现着函数映射的思想,它将数据与其存储位置通过某种函数联系起来,其在查询时的高效性也体现在这 ...

  7. openssl lhash 数据结构哈希表

    哈希表是一种数据结构,通过在记录的存储位置和它的关键字之间建立确定的对应关系,来快速查询表中的数据: openssl lhash.h 为我们提供了哈希表OPENSSL_LHASH 的相关接口,我们可以 ...

  8. Berkeley DB的数据存储结构——哈希表(Hash Table)、B树(BTree)、队列(Queue)、记录号(Recno)

    Berkeley DB的数据存储结构 BDB支持四种数据存储结构及相应算法,官方称为访问方法(Access Method),分别是哈希表(Hash Table).B树(BTree).队列(Queue) ...

  9. python数据结构与算法——哈希表

    哈希表 学习笔记 参考翻译自:<复杂性思考> 及对应的online版本:http://greenteapress.com/complexity/html/thinkcomplexity00 ...

随机推荐

  1. vbnet 进程监控,监控Acad开启的数量,并且添加到开机启动

    1# 自定义函数,添加到注册表 Public Sub StartRunRegHKLM() REM HKEY_LOCAL_MACHINE \ SOFTWARE \ WOW6432Node \ Micro ...

  2. random模块思维导图

  3. [洛谷3930]SAC E#1 - 一道大水题 Knight

    Description 他们经常在一起玩一个游戏,不,不是星际争霸,是国际象棋.毒奶色觉得F91是一只鸡.他在一个n×n的棋盘上用黑色的城堡(车).骑士(马).主教(象).皇后(副).国王(帅).士兵 ...

  4. ACM_同余+暴力找规律

    小光的忧伤 Time Limit: 2000/1000ms (Java/Others) Problem Description: 锴神:我尊重作者原意,你们出什么我就加什么.于是小光打了道水题(也就是 ...

  5. C#知识点-反射

    一.开发环境 操作系统:Win7 编译器:VS2010 .net版本:.net4.0 二.项目结构 三.开发流程 0.编写实体类 namespace ReflectDemo { public clas ...

  6. EasyUI系列学习(六)-Tooltip(提示框)

    一.创建组件 0.Tooltip不依赖其他组件 1.使用class加载 <a href="#" class="easyui-tooltip" title= ...

  7. MVC学习-用EF做增删改查

    在做增删改查先,先介绍几个知识点: 1.代理类 在将对象方法EF数据上下文时,EF会为该对象封装 一个代理类对象, 同时为该对象的每一个属性添加一个标志:unchanged, 当对该对象某个属性进行操 ...

  8. 专题九:实现类似QQ的即时通信程序

    引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net类库去实现它们的.为了让大家更好的理解我们平常中常见的软件QQ的工作原理,所以在 ...

  9. 了解Selenium与自动化测试第一天“云里雾里”

    以前没有搭建过Selenium自动化功能测试环境,想象中就像QTP一样,集成IDE一般简单快捷. 昨天通过博客园的一篇博友日志,才开始大概认识到Selenium的工作方式与特征: 1.插件般与浏览器结 ...

  10. 【linux】 下根目录,家目录区别,以及普通用户到root用户的切换

    一:家目录 一般普通用户,家目录是/home/用户名 root用户,家目录是/root root登录系统,执行如下命令进入root的家目录 cd /cd ~ 进入家目录后执行如下命令获取具体路径 pw ...