c# 实现KMP算法的示例代码

 更新时间:2020年11月23日 08:54:37   作者:温暖如太阳  
这篇文章主要介绍了c# 实现KMP算法的示例代码,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下

KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt提出的,因此人们称它为克努特—莫里斯—普拉特操作(简称KMP算法)。KMP算法的核心是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。具体实现就是通过一个next()函数实现,函数本身包含了模式串的局部匹配信息。KMP算法的时间复杂度O(m+n) 。
实现方式就不再这里献丑了,网上很多讲解,此处只是记录下c#实现的代码。

public class KMP
{
  public static int[] GetNext(String ps)
  {
    char[] p = ps.ToArray();
    int[] next = new int[p.Length];
    next[0] = -1;
    int j = 0;
    int k = -1;
    while (j < p.Length - 1)
    {
      if (k == -1 || p[j] == p[k])
      {
        next[++j] = ++k;
      }
      else
      {
        k = next[k];
      }
    }
    return next;
  }

  public static int GetIndex(String ts, String ps)
  {
    char[] t = ts.ToArray();
    char[] p = ps.ToArray();
    int i = 0; // 主串的位置
    int j = 0; // 模式串的位置
    int[] next = GetNext(ps);
    while (i < t.Length && j < p.Length)
    {
      if (j == -1 || t[i] == p[j])
      { 
        // 当j为-1时,要移动的是i,当然j也要归0
        i++;
        j++;
      }
      else
      {
        // i不需要回溯了
        // i = i - j + 1;
        j = next[j]; // j回到指定位置
      }
    }

    if (j == p.Length)
    {
      return i - j;
    }
    else
    {
      return -1;
    }
  }
}

//test
static void Main(string[] args)
{
  Console.WriteLine( KMP.GetIndex("abcdbcxdbc", "dbc"));
  Console.ReadKey();
}

以上就是c# 实现KMP算法的示例代码的详细内容,更多关于c# kmp算法的资料请关注脚本之家其它相关文章!

相关文章

  • C#拷贝文件简单实现方法

    C#拷贝文件简单实现方法

    这篇文章主要介绍了C#拷贝文件简单实现方法,主要分析了FileInfo类中CopyTo方法针对文件复制的操作技巧,非常简单实用,需要的朋友可以参考下
    2015-04-04
  • C#实现右键快捷菜单(上下文菜单)的两种方式

    C#实现右键快捷菜单(上下文菜单)的两种方式

    在C#中,ContextMenuStrip是一种用于创建右键菜单的控件,它提供了一种方便的方式来为特定的控件或窗体添加自定义的上下文菜单选项,有两种实现方式,文中介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • C#中?、?.、??、??=运算符的用法

    C#中?、?.、??、??=运算符的用法

    本文主要介绍了C#中?、?.、??、??=运算符的用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • C#自动判断Excel版本使用不同的连接字符串

    C#自动判断Excel版本使用不同的连接字符串

    这篇文章主要介绍了C#自动判断Excel版本使用不同的连接字符串,本文重点在不同版本的连接字符串介绍,需要的朋友可以参考下
    2015-06-06
  • C#异步编程由浅入深(三)之详解Awaiter

    C#异步编程由浅入深(三)之详解Awaiter

    这篇文章主要介绍了C#异步编程由浅入深(三)之详解Awaiter,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • Unity 2017使用UGUI实现大转盘抽奖

    Unity 2017使用UGUI实现大转盘抽奖

    这篇文章主要为大家详细介绍了Unity 2017使用UGUI实现大转盘抽奖,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • C#实现给DataGrid单元行添加双击事件的方法

    C#实现给DataGrid单元行添加双击事件的方法

    这篇文章主要介绍了C#实现给DataGrid单元行添加双击事件的方法,较为详细的分析了C#给DataGrid单元添加双击事件的步骤及相关实现代码,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • Unity游戏开发之2048游戏的实现

    Unity游戏开发之2048游戏的实现

    2048是一款数字益智游戏,初始数字则是由2+2组成的基数4。在操作方面的不同则表现为一步一格的移动,变成更为爽快的一次到底。相同数字的方况在靠拢、相撞时会相加。本文将通过Unity3D实现这一游戏,需要的可以参考一下
    2022-03-03
  • C#创建压缩文件的实现代码

    C#创建压缩文件的实现代码

    本篇文章主要介绍了C# 创建压缩文件的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • C#获取哈希加密生成随机安全码的类实例

    C#获取哈希加密生成随机安全码的类实例

    这篇文章主要介绍了C#获取哈希加密生成随机安全码的类,涉及C#哈希加密及字符串操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03

最新评论