博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode] Repeated Substring Pattern 重复子字符串模式
阅读量:5924 次
发布时间:2019-06-19

本文共 2019 字,大约阅读时间需要 6 分钟。

Given a non-empty string check if it can be constructed by taking a substring of it and appending multiple copies of the substring together. You may assume the given string consists of lowercase English letters only and its length will not exceed 10000.

Example 1:

Input: "abab"Output: TrueExplanation: It's the substring "ab" twice.

Example 2:

Input: "aba"Output: False

Example 3:

Input: "abcabcabcabc"Output: TrueExplanation: It's the substring "abc" four times. (And the substring "abcabc" twice.)

这道题给了我们一个字符串,问其是否能拆成n个重复的子串。那么既然能拆分成多个子串,那么每个子串的长度肯定不能大于原字符串长度的一半,那么我们可以从原字符串长度的一半遍历到1,如果当前长度能被总长度整除,说明可以分成若干个子字符串,我们将这些子字符串拼接起来看跟原字符串是否相等。 如果拆完了都不相等,返回false。

解法一:

class Solution {public:    bool repeatedSubstringPattern(string str) {        int n = str.size();        for (int i = n / 2; i >= 1; --i) {            if (n % i == 0) {                int c = n / i;                string t = "";                for (int j = 0; j < c; ++j) {                    t += str.substr(0, i);                 }                if (t == str) return true;            }        }        return false;    }};

下面这种方法是参考的,原作者说是用的KMP算法,LeetCode之前也有一道应用KMP算法来解的题,但是感觉那道题才是KMP算法。这道题也称为KMP算法感觉怪怪的(关于KMP的详细介绍请参见,也可以看博主自己写的一篇),KMP算法中的next数组是找当前位置的最大相同前缀后缀的个数,而这道题维护的一位数组dp[i]表示,到位置i-1为止的重复字符串的字符个数,不包括被重复的那个字符串,什么意思呢,我们举个例子,比如"abcabc"的dp数组为[0 0 0 0 1 2 3],dp数组长度要比原字符串长度多一个。那么我们看最后一个位置数字为3,就表示重复的字符串的字符数有3个。如果是"abcabcabc",那么dp数组为[0 0 0 0 1 2 3 4 5 6],我们发现最后一个数字为6,那么表示重复的字符串为“abcabc”,有6个字符。那么怎么通过最后一个数字来知道原字符串是否由重复的子字符串组成的呢,首先当然是最后一个数字不能为0,而且还要满足dp[n] % (n - dp[n]) == 0才行,因为n - dp[n]是一个子字符串的长度,那么重复字符串的长度和肯定是一个子字符串的整数倍,参见代码如下:

解法二:

class Solution {public:    bool repeatedSubstringPattern(string str) {        int i = 1, j = 0, n = str.size();        vector
dp(n + 1, 0); while (i < n) { if (str[i] == str[j]) dp[++i] = ++j; else if (j == 0) ++i; else j = dp[j]; } return dp[n] && (dp[n] % (n - dp[n]) == 0); }};

本文转自博客园Grandyang的博客,原文链接:,如需转载请自行联系原博主。

你可能感兴趣的文章
Array 的一些常用 API
查看>>
Javascript基础之-Promise
查看>>
8支团队正在努力构建下一代Ethereum
查看>>
程序人生:织梦dedecms后台/会员验证码关闭
查看>>
【Redis源码分析】Redis命令处理生命周期
查看>>
springboot ElasticSearch 简单的全文检索高亮
查看>>
「前端早读君007」css进阶之彻底理解视觉格式化模型
查看>>
微信小程序仿微信SlideView组件slide-view
查看>>
php异常处理的深入
查看>>
【前端芝士树】Javascript的原型与原型链
查看>>
阻止中文输入法输入拼音的时候触发input事件
查看>>
纯css实现漂亮又健壮的tooltip
查看>>
css选择器总结
查看>>
Unexpected end of JSON input while parsing near错误解决方式(网上的方法)
查看>>
Lombok@Builder和@NoArgsConstructor冲突
查看>>
如何在ABAP Netweaver和CloudFoundry里记录并查看日志
查看>>
如何成为有效学习的高手(许岑)——思维导图
查看>>
vue实现todo功能(一):搭建vue-webpack环境
查看>>
美链BEC合约漏洞技术分析
查看>>
Spring 入门学习二之IOC
查看>>