leetcode 28. 找出字符串中第一个匹配项的下标 python

给你两个字符串 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

  • haystackneedle 仅由小写英文字符组成

    python 复制代码
    class Solution:
        def strStr(self, haystack: str, needle: str) -> int:
            if(needle not in haystack):
                return -1
            length1 = len(needle)
            length2 = len(haystack)
            j = 0
            flag = False//定义flag标记是否匹配失败
            for i in range(length2):
                if(haystack[i]==needle[0])://暴力查找
                    flag = True//每次进行匹配重置flag
                    for j in range(length1):
                        if((i+j<length2) and (haystack[i+j]!=needle[j]))://注意下标不要越界
                            flag = False
                            break
                    if(flag):
                        return i
相关推荐
Blossom.11841 分钟前
移动端部署噩梦终结者:动态稀疏视觉Transformer的量化实战
java·人工智能·python·深度学习·算法·机器学习·transformer
AiXed1 小时前
PC微信协议之AES-192-GCM算法
前端·数据库·python
福旺旺2 小时前
Linux——解压缩各类文件
linux
灵光通码2 小时前
神经网络基本概念
python·神经网络
Petrichor_H_3 小时前
DAY 31 文件的规范拆分和写法
python
MasterLi80234 小时前
我的读书清单
android·linux·学习
ha20428941944 小时前
Linux操作系统学习之---初识网络
linux·网络·学习
飞凌嵌入式4 小时前
【玩转多核异构】T153核心板RISC-V核的实时性应用解析
linux·嵌入式硬件·嵌入式·risc-v
陌路204 小时前
Linux 34TCP服务器多进程并发
linux·服务器·网络
玉树临风江流儿4 小时前
Linux驱动开发实战指南-中
linux·驱动开发