【leetcode-字符串】:重复的子字符串(是否由它的一个子串重复多次构成)
题目
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。
示例 1:
输入: "abab"输出: True解释: 可由子字符串 "ab" 重复两次构成。示例 2:
输入: "aba"输出: False示例 3:
输入: "abcabcabcabc"输出: True解释: 可由子字符串 "abc" 重复四次构成。 (或者子字符串 "abcabc" 重复两次构成。)
分析
如果您的字符串 S 包含一个重复的子字符串,那么这意味着您可以多次 “移位和换行”`您的字符串,并使其与原始字符串匹配。
例如:abcabc
移位一次:cabcab
移位两次:bcabca
移位三次:abcabc
现在字符串和原字符串匹配了,所以可以得出结论存在重复的子串。
基于这个思想,可以每次移动k个字符,直到匹配移动 length - 1 次。但是这样对于重复字符串很长的字符串,效率会非常低。在 LeetCode 中执行时间超时了。
为了避免这种无用的环绕,可以创建一个新的字符串 str,它等于原来的字符串 S 再加上 S 自身,这样其实就包含了所有移动的字符串。
比如字符串:S = acd,那么 str = S + S = acdacd
acd 移动的可能:dac、cda。其实都包含在了 str 中了。就像一个滑动窗口
一开始 acd (acd) ,移动一次 ac(dac)d,移动两次 a(cda)cd。循环结束
所以可以直接判断 str 中去除首尾元素之后,是否包含自身元素。如果包含。则表明存在重复子串。
解答
/**
*涉及String方法:append,contains
*/
class Solution {public boolean repeatedSubstringPattern(String s) {StringBuffer sb = new StringBuffer(s);String str = sb.append(s).toString();return str.substring(1,str.length()-1).contains(s);}
}
【leetcode-字符串】:重复的子字符串(是否由它的一个子串重复多次构成)相关推荐
- 重复子字符串(给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。)
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab" 输出: True ...
- js实现kmp算法_「leetcode」459.重复的子字符串:KMP算法还能干这个!
不瞒你说,重复子串问题,KMP很拿手 题目459.重复的子字符串 给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: ...
- LeetCode 459. 重复的子字符串(数学)
1. 题目 给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab" 输出: T ...
- 字符串删除首尾_[LeetCode] 459. 重复的子字符串
题目链接: https://leetcode-cn.com/problems/repeated-substring-pattern 难度:简单 通过率:42.6% 题目描述: 给定一个非空的字符串,判 ...
- qt判断读入的字符串是否含有英文_459. 重复的子字符串
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000.示例 1:输入: "abab"输出: True解释: 可由 ...
- 459. Repeated Substring Pattern 重复的子字符串
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab"输出: True解释: ...
- 0459-Repeated Substring Pattern(重复的子字符串)
这个系列算是出于个人兴趣开的一个新坑吧,最近看到同学刷LeetCode算法题,就想写写那些可以一行Python代码写出来的题目,因此本专栏的文章的解题方式效率不做保证,只为追求"一行的浪漫& ...
- leetcode459. 重复的子字符串
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab" 输出: True 解释 ...
- qt判断读入的字符串是否含有英文_重复的子字符串
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000.示例 1:输入: "abab"输出: True解释: 可由 ...
- 力扣leetCode459之重复的子字符串(双倍字符串解法)Java
题目描述: 给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab" 输出: T ...
最新文章
- OpenCASCADE:OCCT应用框架OCAF之标准文件服务
- 2015-03-19 header note update in my Appointment
- jmeter中控制器其中一个访问不到_Jmeter你所不知道的知识点!
- Java基础学习总结(82)——Java泛型实例教程
- python人工智能能干啥_人工智能首选什么语言 Python能做哪些事情
- 二逼平衡树 题解(树套树)
- Dxg——[版本管理工具Git SVN]开发笔记整理分类合集【所有的相关记录,都整理在此】
- 由于dns服务为启动导致的GI集群启动故障
- php yof框架特点_PHP编程语言的特点
- mysql初始化密码_MySQL5.7初始密码查看及重置
- 【Spring Data ElasticSearch】高级查询,聚合
- office 2003也能编辑.docx文档
- 大数据技术之电商推荐系统(6) | 基于LFM的离线推荐模块
- put: File COPYING could be replicated to 0 nodes instead of minReplication.There are 0 datanodes解决方案
- java finalize方法总结、GC执行finalize的过程
- 【C语言】变量和常量、数据类型、进制转换、数据存储
- fisco bcos使用在线IDE chainIDE教程,只要有网络就可以写智能合约!
- FPGA:双口RAM
- Nvme固体硬盘Intel750,SM961分别使用一段时间以后对比
- Andorid Studio中运行模拟器--夜神模拟器