算法刷题Day9 | 28. 实现 strStr()、459.重复的子字符串、字符串总结

2024-03-14 23:04

本文主要是介绍算法刷题Day9 | 28. 实现 strStr()、459.重复的子字符串、字符串总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 0 引言
  • 1 实现 strStr()
    • 1.1 我的解题
    • 1.2 KMP算法解题
  • 2 重复的子字符串
    • 2.1 暴力求解
    • 2.2 KMP求解法
  • 3 字符串总结

请添加图片描述

  • 🙋‍♂️ 作者:海码007
  • 📜 专栏:算法专栏
  • 💥 标题:算法刷题Day8 | 28. 实现 strStr()、459.重复的子字符串、字符串总结
  • ❣️ 寄语:书到用时方恨少,事非经过不知难!

0 引言

1 实现 strStr()

  • 🎈 文档讲解:https://programmercarl.com/0028.%E5%AE%9E%E7%8E%B0strStr.html
  • 🎈 视频讲解:最浅显易懂的 KMP 算法讲解
  • 🎈 做题状态:KMP算法的next数组的求解还是有点懵

1.1 我的解题

暴力解题:直接两个循环

class Solution {
public:int strStr(string haystack, string needle) {for(int i = 0; i < haystack.size(); i++){int j = 0;for (; j < needle.size(); j++){if (haystack[i+j] != needle[j]){// 如果第一个数都不匹配,则直接跳出循环break;}}// 如果全部的数都匹配,则此时 j == needle.size()if (j == needle.size()){return i;}}return -1;}
};

1.2 KMP算法解题

KMP的经典思想就是:当出现字符串不匹配时,可以记录一部分之前已经匹配的文本内容,利用这些信息避免从头再去做匹配。
在这里插入图片描述

如上图所示,只需要我们找到已经匹配过的字符串中前缀和后缀相等的个数,就知道下一次遍历,子串应该从哪个位置开始。例如下图中,在C处不匹配时,我们只需要找出 ABAB 这个字符串,最小的前后串相等的个数是多少,就知道下次遍历子串该从哪个位置开始。 对于 ABAB 字符串,可以得知最小前后串相等的个数是2。所以子串从 (2+1)的位置开始遍历,也就是从 索引为 2 的位置开始遍历。因为主串中末尾匹配的字符对应 ABAB 的后缀。而我们已经知道 ABAB 的 AB前缀和AB后缀是相等的。所以此时 AB 前缀也就不需要再和主串中末尾的 AB 进行比较了。

在这里插入图片描述

现在知道匹配的基本原理后,下一步的任务就是求解 前缀表 也就是子串中当前字符前面的字符串的相同前后缀的长度是多少。也就是next数组。

在这里插入图片描述

使用递推求解next数组:

next数组(前缀表)求解的步骤:
初始化、前后缀不相同的情况、前后缀相同的情况、更新next数组

  1. 初始化,两个索引值,分别指向前缀末尾(索引 j )和后缀末尾(索引 i )。首先初始化 j=0; next[0] = 0;
  2. 遍历 i ,当前后缀不相等时,
  

2 重复的子字符串

  • 🎈 文档讲解:https://programmercarl.com/0459.%E9%87%8D%E5%A4%8D%E7%9A%84%E5%AD%90%E5%AD%97%E7%AC%A6%E4%B8%B2.html
  • 🎈 视频讲解:https://www.bilibili.com/video/BV1M5411j7Xx/?spm_id_from=333.788&vd_source=d499e7f3a8e68e2b173b1c6f068b2147
  • 🎈 做题状态:

2.1 暴力求解

2.2 KMP求解法

3 字符串总结

字符串是若干字符组成的有限序列,也可以理解为是一个字符数组,但是很多语言对字符串做了特殊的规定,接下来我来说一说C/C++中的字符串。

在C语言中,把一个字符串存入一个数组时,也把结束符 '\0’存入数组,并以此作为该字符串是否结束的标志。
在使用 string 的时候直接把他看作一个字符数组会便于理解。

这篇关于算法刷题Day9 | 28. 实现 strStr()、459.重复的子字符串、字符串总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/809996

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景