0
点赞
收藏
分享

微信扫一扫

Dockerfile命令

1.题目描述

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

2.样例描述

3.思路描述

可以让字符串 needle 与字符串 haystack 的所有长度为 mmm 的子串均匹配一次。

为了减少不必要的匹配,每次匹配失败即立刻停止当前子串的匹配,对下一个子串继续匹配。如果当前子串匹配成功,返回当前子串的开始位置即可。如果所有子串都匹配失败,则返回 −1。

4.代码展示

class Solution {
    public int strStr(String haystack, String needle) {
        int n = haystack.length(), m = needle.length();
        for (int i = 0; i + m <= n; ++i) {
            boolean flag = true;
            for (int j = 0; j < m; ++j) {
                if (haystack.charAt(i + j) != needle.charAt(j)) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                return i;
            }
        }
        return -1;
    }
}
int strStr(char * haystack, char * needle){
    int len1 =strlen(haystack);
    int len2 =strlen(needle);

    if(len1<len2)
        return -1;

    int i=0;
    int j=0;
    int t=i;
    while(haystack[i] && needle[j])
    {
         if(haystack[i] == needle[j])
            {
                i++;
                j++;
                continue;
            }
            else
            {
                t=t+1;
                i=t;
                j=0;
            }
        
    }

    if(needle[j] == '\0')
        return t;
    return -1;
}
举报

相关推荐

0 条评论