golang字符串匹配算法

简介

字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为模式串)。在 Golang 中,可以使用最常见的字符串匹配算法之一:Knuth-Morris-Pratt(KMP)算法,它的时间复杂度为 O(n+m),其中 n 和 m 分别为文本串和模式串的长度。

KMP实现代码

mermaid解说图
在这里插入图片描述

package main

import "fmt"

// KMP 算法用于在一个文本串中查找一个模式串
// 其中,text 为文本串,pattern 为模式串
// 返回值为模式串在文本串中第一次出现的位置,如果未找到,则返回 -1
func kmp(text, pattern string) int {
	n, m := len(text), len(pattern)
	if m == 0 {
		return 0
	}
	if n < m {
		return -1
	}

	// 构建前缀表(partial match table)
	pmt := make([]int, m)
	for i, j := 1, 0; i < m; i++ {
		// 寻找最长公共前后缀的长度
		for j > 0 && pattern[i] != pattern[j] {
			j = pmt[j-1]
		}
		if pattern[i] == pattern[j] {
			j++
		}
		pmt[i] = j
	}

	// 在文本串中匹配模式串
	for i, j := 0, 0; i < n; i++ {
		// 如果匹配不成功,利用前缀表来找到一个新的匹配位置
		for j > 0 && text[i] != pattern[j] {
			j = pmt[j-1]
		}
		// 如果匹配成功,则继续匹配下一个字符
		if text[i] == pattern[j] {
			j++
		}
		// 如果匹配成功,返回模式串在文本串中第一次出现的位置
		if j == m {
			return i - m + 1
		}
	}
	// 如果未找到,则返回 -1
	return -1
}

func main() {
	var num = kmp("韩实施一个如何使得覅上的换个地方韩浩", "韩浩")
	fmt.Println(num)
}

在此实现中,我们首先构建了模式串的前缀表(partial match table,简称 pmt)。该表的每个元素表示模式串中前缀和后缀的最长公共部分的长度,即当模式串匹配到某个位置时,如果发生不匹配,则利用前缀表来找到一个新的匹配位置,以减少不必要的匹配操作。

接着,我们在文本串中匹配模式串,如果匹配成功,则返回模式串在文本串中第一次出现的位置,否则返回 -1。

使用 KMP 算法可以提高字符串匹配的效率,特别是当模式串较长时,它可以减少不必要的字符比较操作,从而提高匹配速度。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hello.Reader

请我喝杯咖啡吧😊

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值