博客
关于我
leetcode-28-Implement strStr()
阅读量:806 次
发布时间:2023-01-31

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

为了解决这个问题,我们需要编写一个函数来查找 haystack 中首次出现的 needle 子字符串的索引,如果 needle 不在 haystack 中,则返回 -1。

方法思路

为了高效地解决这个问题,我们可以采用以下步骤:

  • 处理特殊情况

    • 如果 needle 为空字符串,返回 0,因为空字符串可以被认为是任何字符串的子字符串。
    • 如果 haystack 为空字符串,而 needle 不为空,返回 -1,因为空字符串无法包含非空子字符串。
    • 如果 needle 和 haystack 都为空字符串,返回 0。
  • 检查长度

    • 如果 haystack 的长度小于 needle 的长度,返回 -1,因为 needle 无法出现在 haystack 中。
  • 查找子字符串

    • 遍历 haystack,从第一个字符开始,直到 haystack 可以包含 needle 的最后一个位置。
    • 使用 substr 方法提取子字符串进行比较,如果找到匹配项,返回当前索引;否则,遍历结束后返回 -1。
  • 这种方法的时间复杂度为 O(n*m),其中 n 是 haystack 的长度,m 是 needle 的长度。在大多数情况下,这是一个可接受的时间复杂度,适用于一般的字符串查找问题。

    解决代码

    #include 
    using namespace std;int strStr(string haystack, string needle) { // 如果 needle 为空,返回 0 if (needle.empty()) { return 0; } // 如果 haystack 为空,则不能包含 needle,返回 -1 if (haystack.empty()) { return -1; } // 检查 haystack 的长度是否大于等于 needle 的长度 int haystackLength = haystack.length(); int needleLength = needle.length(); if (haystackLength < needleLength) { return -1; } // 遍历 haystack, 从开始到 haystackLength - needleLength 的位置 int maxIndex = haystackLength - needleLength; for (int i = 0; i <= maxIndex; ++i) { string sub = haystack.substr(i, needleLength); if (sub == needle) { return i; } } // 如果遍历完都没找到,返回 -1 return -1;}

    代码解释

    • 处理特殊情况:检查针是否为空字符串,根据情况返回相应的值。
    • 长度检查:如果 haystack 的长度小于 needle 的长度,直接返回 -1。
    • 遍历查找:从 haystack 的起始位置开始,逐步提取子字符串进行比较,找到匹配项后返回当前索引。遍历结束后如果没有找到,返回 -1。

    这种方法确保了代码的正确性和高效性,同时也处理了所有边界情况。

    转载地址:http://algyk.baihongyu.com/

    你可能感兴趣的文章
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_使用NIFI表达式语言_来获取自定义属性中的数据_NIFI表达式使用体验---大数据之Nifi工作笔记0024
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群2_实际操作搭建NIFI内嵌模式集群---大数据之Nifi工作笔记0016
    查看>>