【力扣】28. 找出字符串中第一个匹配项的下标

简介: 【力扣】28. 找出字符串中第一个匹配项的下标

题目描述

给你两个字符串 haystackneedle ,请你在 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 。


提示:


1 <= haystack.length, needle.length <= 104

haystack 和 needle 仅由小写英文字符组成

解题方法

  • C
int strStr(char* haystack, char* needle)
{
    int m = strlen(haystack), n = strlen(needle);   // 获取字符串长度

    for(int i = 0; i <= m - n; i++)                 // 遍历 haystack,只需 m-n 次
    {
        int j = i, k = 0;
        while(k < n && haystack[j] == needle[k])    // 是否匹配
        {
            j++;        // 继续匹配
            k++;
        }
        if(k == n)      // 匹配成功
        {
            return i;   // 返回匹配开始的索引
        }
    }
    return -1;          // 匹配失败
}


相关文章
|
2月前
|
存储 算法
LeetCode第43题字符串相乘
LeetCode第43题"字符串相乘"的解题方法,通过使用数组存储乘积并处理进位,避免了字符串转换数字的复杂性,提高了算法效率。
LeetCode第43题字符串相乘
|
2月前
|
算法 Java
LeetCode第28题找出字符串中第一个匹配项的下标
这篇文章介绍了LeetCode第28题"找出字符串中第一个匹配项的下标"的两种解法:暴力解法和KMP算法,并解释了KMP算法通过构建前缀表来提高字符串搜索的效率。
LeetCode第28题找出字符串中第一个匹配项的下标
|
2月前
|
算法
LeetCode第8题字符串转换整数 (atoi)
该文章介绍了 LeetCode 第 8 题字符串转换整数 (atoi)的解法,需要对字符串进行格式解析与校验,去除前导空格和处理正负号,通过从高位到低位的计算方式将字符串转换为整数,并处理越界情况。同时总结了这几道题都需要对数字的表示有理解。
LeetCode第8题字符串转换整数 (atoi)
|
4月前
|
算法
力扣每日一题 6/23 字符串/模拟
力扣每日一题 6/23 字符串/模拟
31 1
|
4月前
力扣经典150题第四十题:同构字符串
力扣经典150题第四十题:同构字符串
29 1
|
4月前
|
索引
力扣每日一题 6/27 字符串 贪心
力扣每日一题 6/27 字符串 贪心
27 0
|
4月前
|
Python
力扣随机一题 模拟+字符串
力扣随机一题 模拟+字符串
24 0
|
4月前
力扣每日一题 6/22 字符串/贪心
力扣每日一题 6/22 字符串/贪心
23 0
|
4月前
力扣每日一题 6/18 字符串/模拟
力扣每日一题 6/18 字符串/模拟
22 0
|
4月前
|
算法
力扣每日一题 6/16 字符串 + 随机一题 动态规划/数学
力扣每日一题 6/16 字符串 + 随机一题 动态规划/数学
32 0