Leetcode 459:重复的子字符串

给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。

示例 1:

复制代码
输入: s = "abab"
输出: true
解释: 可由子串 "ab" 重复两次构成。

示例 2:

复制代码
输入: s = "aba"
输出: false

示例 3:

复制代码
输入: s = "abcabcabcabc"
输出: true
解释: 可由子串 "abc" 重复四次构成。 (或子串 "abcabc" 重复两次构成。)

解题思路:

1.如果s存在重复字串,则将t掐头去尾以后,一定还存在一个s;

2.先去掉t的首尾字符(下标从1开始,到length-2结束);

3.找t中是否存在一个s。

java 复制代码
public class title459 {

	public static void main(String[] args) {
		
		String s="ababab";
		boolean result = repeatedSubstringPattern(s);
		System.out.println(result);
		
	}
	
	
	public static boolean repeatedSubstringPattern(String s) {

		String t=s+s;
		int j=0;
		int[] next=getNext(s);
		for(int i=1;i<t.length()-1;i++) {
			while(j>0&& t.charAt(i)!=s.charAt(j)) {
				j=next[j-1];
			}
			if(t.charAt(i)==s.charAt(j)) {
				j++;
			}
			if(j==s.length()){
				return true;
			}
		}
		return false;
    }
	
	//求next数组
	public static int[] getNext(String s) {
		int[] next = new int[s.length()];
		int j=0;
		next[0]=0;
		for(int i=1;i<s.length();i++) {
			while(j>0 && s.charAt(i)!=s.charAt(j)) {
				j=next[j-1];
				
			}
			if(s.charAt(i)==s.charAt(j)) {
				j++;
			}
			next[i]=j;
		}
		return next;
	}

}
相关推荐
_shenash3 分钟前
Linux C高级 day1
linux·运维·服务器
hardStudy_h8 分钟前
Linux——创建编写并编译一个C程序
linux·运维·服务器
HHONGQI12311 分钟前
Linux 基础入门操作 第九章 进程之间通讯信号量
linux
shangan_331 分钟前
JAVA随机排名
java·算法·排序算法
威哥爱编程43 分钟前
除了递归算法,要如何优化实现文件搜索功能
java·算法·递归·memoization
程序员波特1 小时前
基础数据结构之链表
java·数据结构·算法
害羞的白菜1 小时前
Nginx基础详解1(单体部署与集群部署、负载均衡、正反代理、nginx安装)
linux·运维·服务器·nginx·centos·云计算·负载均衡
Kenneth風车1 小时前
【第十二章:Sentosa_DSML社区版-机器学习之回归】
人工智能·算法·低代码·机器学习·数据挖掘·数据分析·回归
鱼跃鹰飞1 小时前
Leetcode面试经典150题-172.阶乘后的零
java·算法·leetcode·面试·职场和发展
安 度 因1 小时前
【项目】多设计模式下的同步异步日志系统
linux·运维·服务器·日志