力扣-28. 找出字符串中第一个匹配项的下标(内置函数或双指针)

  1. 找出字符串中第一个匹配项的下标
    给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 0 开始)。如果 needle 不是 haystack

的一部分,则返回 -1 。

示例 1:

输入:haystack = "sadbutsad", needle = "sad" 输出:0 解释:"sad" 在下标 0 和 6 处匹配。

第一个匹配项的下标是 0 ,所以返回 0 。 示例 2:

输入:haystack = "leetcode", needle = "leeto" 输出:-1 解释:"leeto" 没有在

"leetcode" 中出现,所以返回 -1 。

  • indexOf(String str, int index):
    返回从index位置开始查找指定字符str在字符串中第一次出现处的起始索引,如果此字符串中没有这样的字符,则返回 -1。
java 复制代码
class Solution {
    public int strStr(String haystack, String needle) {
        return haystack.indexOf(needle);
    }
}
  • 双指针解决
    思路:一个指针去遍历haystack,当遇到相等的时候,去依次遍历needle看看是否全部相等,如果没有的话,继续遍历haystack
java 复制代码
class Solution {
    public int strStr(String haystack, String needle) {
        if(needle=="") return -1;
         int hlength=haystack.length();
         int nlength=needle.length();
         int index=-1;
         for(int i=0;i<hlength;i++){
            if(hlength-i<nlength)
            break;
            if(haystack.charAt(i)==needle.charAt(0)){
                index=i;
                for(int j=1;j<nlength;j++){
                    i++;
                    if(needle.charAt(j)!=haystack.charAt(i))
                   { i=index;
                     index=-1;
                    break;
                   }

                }
                if(index!=-1)
                break;
            }

         }
         return index;
    }
}
相关推荐
参.商.1 分钟前
【Day43】49. 字母异位词分组
leetcode·golang
m0_5698814710 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
笒鬼鬼11 分钟前
【API接口】最新可用红果短剧接口
算法·api·笒鬼鬼·红果短剧·接口源码
weixin_4219226912 分钟前
C++与边缘计算
开发语言·c++·算法
2401_8319207415 分钟前
C++编译期数组操作
开发语言·c++·算法
蝎子莱莱爱打怪20 分钟前
别再裸用 Claude Code 了!32 个亲测Skills + 8 个 MCP,开发效率直接拉满!
java·后端·claude
殷紫川22 分钟前
秒杀系统高并发核心优化与落地全指南
算法·架构
野犬寒鸦33 分钟前
JVM垃圾回收机制面试常问问题及详解
java·服务器·开发语言·jvm·后端·算法·面试
风酥糖40 分钟前
Godot游戏练习01-第16节-游戏中的状态机
算法·游戏·godot
参.商.42 分钟前
【Day45】647. 回文子串 5. 最长回文子串
leetcode·golang