当前位置: 首页 > news >正文

算法力扣刷题 二十六【459.重复的子字符串】

前言

字符串篇,继续。
记录 二十六【459.重复的子字符串】


一、题目阅读

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

示例 1:

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

示例 2:

输入: s = "aba"
输出: false

示例 3:

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

提示:

1 <= s.length <= 104
s 由小写英文字母组成

二、尝试实现

思路

上一篇学到匹配字符串可以用KMP算法,用来查找“文本串”中有没有“模式串”。用到前缀表
乍一看题目,觉得也是匹配的问题,所以用前缀表试一下。
(1)对string s求出next数组。(数组保持原始数值,next[0] == 0)
(2)如果能知道从哪里开始重复就好了,在此之前的长度是x,是最小的重复单元。用size%x ==0,说明满足条件,return true。否则return false。
(3)怎么找规律,找最小重复单元

  • next某个位置等于1,后面的值都递增。发现开始重复的位置next值为1,往后2,3,4……,找next中哪个位置等于0?倒着往前找哪个next等于1?倒着往前找递减,并且终止在1,?这都不全面,有些用例无法通过,实现不了。

所以:获得next数组之后怎么确定最小重复单元呢?这是个关键。


三、代码随想录学习

学习内容

继续二、中的思路,获取到next数组后,学习到:

  • 只需要看next[size-1],最后一位的数值。最长相等前后缀的含义,给出了最小重复单元
  • 图示讲解推理过程。
    在这里插入图片描述
  • size - next[size-1] :最小重复单元的长度,如果size可以除尽,说明返回true;否则返回false。
  • next[size-1] != 0再做减法。

代码实现

class Solution {
public://求前缀表void getNext(int* next,string& s){next[0] = 0;int j=0;for(int i = 1;i < s.size();i++){while(j >0 && s[j] != s[i]){j = next[j-1];}if(s[j] == s[i]){j++;}next[i] = j;}return;}bool repeatedSubstringPattern(string s) {int size = s.size();int* next = new int[size]{0};getNext(next,s);if(next[size-1] != 0 &&size%(size-next[size-1]) == 0){	//在next[size-1]!= 0前提下,确定最小重复单元的长度,判断是否整除return true;}else{return false;}}
};

总结

KMP用前缀表找匹配很有用。利用前缀 = 后缀,并且最长的“含义”来找所求。

(欢迎指正,转载标明出处)

http://www.lryc.cn/news/388100.html

相关文章:

  • 【Linux】虚拟机安装openEuler 24.03 X86_64 教程
  • 分布式事务:理论与实践
  • 5、双足机器人mpc动力学模型
  • 虚拟机配置与windows之间文件夹共享samba服务:
  • 探索音频创作的无限可能——Studio One 5 软件深度解析
  • CSS Flex弹性布局
  • 第十六章:基于开源大模型使用huggingface在deepspeed与accelerator下继承源码权重保存而实现resume与infer
  • ZooKeeper 入门:初学者指南
  • 【数据结构(邓俊辉)学习笔记】二叉搜索树04——AVL树
  • SpringMVC基础详解
  • SQL SERVER 设置端口
  • 华芯微特2024慕尼黑上海电子展预告
  • DETR End-to-End Object Detection with Transformers
  • 【后端面试题】【中间件】【NoSQL】ElasticSearch 节点角色、写入数据过程、Translog和索引与分片
  • 【TB作品】玩具电子琴,ATMEGA128单片机,Proteus仿真
  • 1974Springboot医院远程诊断管理系统idea开发mysql数据库web结构java编程计算机网页源码maven项目
  • SQL游标的应用场景及使用方法
  • LLama-Factory使用教程
  • Java面试题:讨论在Java Web应用中实现安全的认证和授权机制,如使用Spring Security
  • 如何在Vue3项目中使用Pinia进行状态管理
  • 【初阶数据结构】深入解析队列:探索底层逻辑
  • Go 语言环境搭建
  • javascript v8编译器的使用记录
  • C语言--vs使用调试技巧
  • Spring Boot中的国际化配置
  • WPF的IValueConverter用于校验和格式化TextBox的数字输入
  • SQL Server的守护神:Always On 高可用性详解
  • Eureka入门
  • 高阶面试-netty部分
  • 在 C++的跨平台开发中,如何处理不同操作系统和编译器之间的细微差异,以确保程序能够稳定且高效地运行?