一、寻找一个字符串中的最长重复子串(后缀数组)
后缀数组其实可以看寻找一个字符串中的最长重复子串(后缀数组)作一个由字符串s倒数i个字符组成的子串的集合,其中0<i<s.length(),例如 字符串strstr的后缀数组为: {r,tr,str,rstr,trstr,strstr}
得到这个集合之后,我们可以发现,最长重复子串其实变成了求该集合中任意两个元素的最长公共前缀的问题。因为在这个集合中,原字符串中的每个字符都会出现在集合中元素的首位,而如果有子串重复出现,那么该子串肯定会出现在某两个或者多个元素的公共前缀上。
接下来问题就变成了如何去寻找最长公共前缀,除了暴力搜素之外,我们可以考虑先对该集合中的元素按照字典序进行排序,然后依次比较相邻的元素,找出其中的最长公共前缀即可。
https://dsqiu.iteye.com/blog/1701324
https://blog.youkuaiyun.com/kongdavid/article/details/38405475
https://blog.youkuaiyun.com/htq__/article/details/50855769
二、找出一个字符串中最长不重复子串(python)
https://blog.youkuaiyun.com/together_cz/article/details/77533121

本文介绍两种字符串处理算法:一是利用后缀数组寻找最长重复子串,通过字典序排序和比较找到公共前缀;二是用Python实现查找最长不重复子串的方法。这两项技能对于解决字符串相关问题非常实用。
1114

被折叠的 条评论
为什么被折叠?



