3097: Hash Killer I

Time Limit: 5 Sec  Memory Limit: 128 MBSec  Special Judge
Submit: 425  Solved: 157
[Submit][Status][Discuss]

Description

这天天气不错,hzhwcmhf神犇给VFleaKing出了一道题:
给你一个长度为N的字符串S,求有多少个不同的长度为L的子串。
子串的定义是S[l]、S[l + 1]、... S[r]这样连续的一段。
两个字符串被认为是不同的当且仅当某个位置上的字符不同。

VFleaKing一看觉得这不是Hash的裸题么!于是果断写了哈希 + 排序。
而hzhwcmhf神犇心里自然知道,这题就是后缀数组的height中 < L的个数 + 1,就是后缀自动机上代表的长度区间包含L的结点个数,就是后缀树深度为L的结点的数量。
但是hzhwcmhf神犇看了看VFleaKing的做法表示非常汗。于是想卡掉他。

VFleaKing使用的是字典序哈希,其代码大致如下:
u64 val = 0;
for (int i = 0; i < l; i++)
 val = val * base + s[i] - 'a';
u64是无符号int64,范围是[0, 2^64)。VFleaKing让val自然溢出。
base是一个常量,VFleaKing会根据心情决定其值。
VFleaKing还求出来了base ^ l,即base的l次方,这样就能方便地求出所有长度为L的子串的哈希值。
然后VFleaKing给哈希值排序,去重,求出有多少个不同的哈希值,把这个数作为结果。
其算法的C++代码如下:

typedef unsigned long long u64;

const int MaxN = 100000;

inline int hash_handle(const char *s, const int &n, const int &l, const int &base)
{
 u64 hash_pow_l = 1;
 for (int i = 1; i <= l; i++)
  hash_pow_l *= base;

int li_n = 0;
 static u64 li[MaxN];

u64 val = 0;
 for (int i = 0; i < l; i++)
  val = val * base + s[i] - 'a';
 li[li_n++] = val;
 for (int i = l; i < n; i++)
 {
  val = val * base + s[i] - 'a';
  val -= (s[i - l] - 'a') * hash_pow_l;
  li[li_n++] = val;
 }

sort(li, li + li_n);
 li_n = unique(li, li + li_n) - li;
 return li_n;
}

hzhwcmhf当然知道怎么卡啦!但是他想考考你。

Input

没有输入。

Output

你需要输出一组数据使得VFleaKing的代码WA掉。我们会使用Special Judge检查你的结果的正确性。
输出文件共两行。
第一行两个用空格隔开的数n、l。
第二行是一个长度为n的字符串。只能包含'a'~'z'。
需要保证1 <= n <= 10^5, 1 <= l <= n,
不符合以上格式会WA。
不要有多余字符,很可能导致你WA。

Sample Input

没有

Sample Output

8 4
buaabuaa
(当然这个输出是会WA的)

HINT

orz 波兰人 & fotile96 & sillycross

Source

 
题解:哈希神题不解释——对于C++的自然溢出神马的(PASCAL没有。。。TT),关键就在于构造关于2^64-1时hash值相同的字串

具体见(VFK博客 3097 3098 3099: Hash Killer I II III),orz orz orz

 /**************************************************************
Problem:
User: HansBug
Language: Pascal
Result: Accepted
Time: ms
Memory: kb
****************************************************************/ var
i,j,k,l,m,n:longint;
s:array[..] of char;
begin
n:=;s[]:='a';
for i:= to do
begin
for j:= to n- do
if s[j]='a' then s[j+n]:='b' else s[j+n]:='a';
n:=n shl ;
end;
l:=n shr ;
s[n]:='a';inc(n);
for i:= to l- do
begin
s[n]:='a';
inc(n);
end;
s[n]:='b';inc(n);
for i:= to l- do
begin
s[n]:='a';
inc(n);
end;
writeln(n,' ',l);
writeln(s);
readln;
end.

最新文章

  1. OC中的字典NSDictionary
  2. 第三十二课:JSDeferred的性能提速
  3. note.js之 Nodejs+Express4在windows下的配置
  4. hdu 4115 2-SAT判定
  5. Hadoop Configuration
  6. 使用Google Chart API绘制组合图
  7. ORA-28001: the password has expired
  8. leetcode 逆转字符串 当年的第一题,今天再写一遍,物是人非
  9. autoit使用
  10. BZOJ 1579: [Usaco2009 Feb]Revamping Trails 道路升级( 最短路 )
  11. git常用命令2
  12. 快速构建Windows 8风格应用15-ShareContract构建
  13. 关于JAVAweb的一些东西
  14. javascript form提交 不执行onsubmit事件解决方案
  15. 使用kube_ping进行Keycloak群集设置 - DZone Cloud
  16. mysql数据导入导出方法总结
  17. sudo apt-get update 去除设置的代理
  18. 极小极大搜索方法、负值最大算法和Alpha-Beta搜索方法
  19. python---CRM用户关系管理
  20. Android Studio奇技淫巧

热门文章

  1. Boost.Asio技术文档
  2. 走进React
  3. C++ 头文件系列(forward_list)
  4. 机器学习实战笔记(1)——k-近邻算法
  5. 《JAVASCRIPT高级程序设计》第五章(2)
  6. oracle_权限
  7. mybatis入门-新手注意问题
  8. bzoj1492--斜率优化DP+cdq分治
  9. Maven入门,Maven项目的创建,nexus 2.x搭建私服以及Maven多模块项目创建
  10. C# XmlSerializer将对象序列化以及反序列化(Sqlite数据库)