PowerBI技巧之POJ 2406 Power Strings(后缀数组[连续重复子串]).pdfVIP

PowerBI技巧之POJ 2406 Power Strings(后缀数组[连续重复子串]).pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
此此文文章章可可以以使使用用目目录录功功能能哟哟↑(点点击击上上方方[+]) 题集链接→Waterloo local 2002.07.01 POJ 2406 Power Strings Accept: 0 Submit: 0 Time Limit: 3000 MS Memory Limit : 65536 Problem Description Given two strings a and b we define a*b to be their concatenation. For example, if a = abc and b = def then a*b = abcdef. If we think of concatenation as multiplication, ex ponentiation b a non-negative integer is defined in the normal wa : a^0 = (the empt string) and a^(n+1) = a*(a^n). Input Each test case is a line of input representing s, a string of printable characters. The length of s will be at least 1 and will not exceed 1 million characters. A line containing a period follows the last test case. Output For each s you should print the largest n such that s = a^n for some string a. Sample Input abcd aaaa ababab . Sample Output 1 4 3 Hint This problem has huge input, use scanf instead of cin to avoid time limit exceed. Problem Idea 解题思路: 【题意】 如果一个字 串L是由某个字 串S重复R次而得到的, 则称L是一个连续重复串。 R是这个字 串的重复次数。 现在给你一个连续重复串L,问R最大为多少 【类型】 后缀数组[连续重复子串] 【分析】 此题的解法有很多种,但由于博主最近在学后缀数组,故以后缀数组的方法来求解 连续重复子串解法(摘自罗穗骞的国家集训队论文): 穷举字 串S的长度k ,然后判断是否满足。判断的时候,先看字 串L的长度能否被k整除,再看suffix( 1)和suffix(k+ 1) 的最长公共前缀是否等于 -k 。在询问最长公共前缀的时候, suffix( 1)是固定的,所以RMQ 问题没有必要做所有的预处理,只需求出 height 数组中的每一个数到 height[ra k[1]]之间的最小值即可。整个做法的时间复杂度为O( ) 。 接着,我们来好好解释一下这种解法 穷举字 串S的长度k ,然后判断是否满足,判断条件有两个: ①字 串L的长度能否被k整除; 这个条件很显然,若是不能被k整除,又如何能够由此字 串翻转k次得到 ②suffix( 1)和suffix(k+ 1) 的最长公共前缀是否等于 -k 。 这个条件其实也蛮好理解的,具体见下图 而计算suffix( 1)和suffix( 1+k) 的最长公共前缀,一般可采用RMQ预处理,但是本题如果采用RMQ的话,会导致MLE,毕竟是1000000*20的数组,而且后 缀数组还花去了一部分开销 由于区间一端已经固定(即suffix( 1)),所以我们可以花O( )时间预处理出 height 数组中的每一个数到height[ra k[1]]之间的最小值 ps :此题卡倍增算法(O( log )) ,故需使用DC3算法(O( ))才可以过 【时间复杂度优化】 O(n) 题目链接→POJ 2406 Power Strings Source Code /*Sherlock and Watson and Adler*/

您可能关注的文档

文档评论(0)

精通微软Word、Excel、PowerPoint、PowerBI,资料达人。

1亿VIP精品文档

相关文档