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

class Solution:
    def strStr(self, haystack: str, needle: str) -> int:
	
	# 基本情况
        if len(haystack) == 0 or len(needle) == 0:
            return -1
        if len(haystack) == 1 and len(needle) == 1:
            if haystack != needle:
                return -1
            else:
                return 0
        if len(needle) == 1:
            for i in range(len(haystack)):
                if haystack[i] == needle:
                    return i
            return -1

		# 动态规划生成next数组 
        def generateNext(needle):
            next_arr = [-1 for i in range(len(needle))]
            next_arr[1] = 0


            for i in range(2, len(next_arr)):
                k = next_arr[i-1]
                while needle[i-1] != needle[k] and k != 0:
                    k = next_arr[k]
                if needle[i-1] == needle[k]:
                    next_arr[i] = k + 1 
                else:
                    next_arr[i] = 0
                

            return next_arr
        next_arr = generateNext(needle)

		# 匹配代码,i为haystack的指针,j为needle(pattern)的指针
        i = 0
        j = 0
        while i + len(needle) - j <= len(haystack):
            if haystack[i] == needle[j]:
                i += 1
                j += 1
            else:
            	# 暴力法这里的i不是减next_arr[j]回退,而是减整个patter长度回退。kmp
            	# 在这里做文章
                i = i - next_arr[j]
                j = 0
                
            if j == len(needle):
                return i - len(needle)
        return -1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值