当前位置:首页 > PHP教程 > php应用 > 列表

php中字符串匹配KMP算法实现例子

发布:smiling 来源: PHP粉丝网  添加日期:2015-04-09 16:04:24 浏览: 评论:0 

KMP算法是一个比较高级的算法了,加了改进了,下面我们来在php中实现KMP算法,希望例子对各位同学会带来帮助,kmp算法是一种改进的字符串匹配算法,由D.E.Knuth与V.R.Pratt和J.H.Morris同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法),KMP算法的关键是根据给定的模式串W1,m,定义一个next函数,next函数包含了模式串本身局部匹配的信息.

例子,代码如下:

  1. <?php 
  2. /* 
  3. 字符串匹配KMP算法的PHP语言实现 
  4. */ 
  5. function KMP($str) { 
  6.     $K = array(0); 
  7.     $M = 0; 
  8.     $strLen = strlen($str); 
  9.     for($i=1; $i<$strLen$i++) { 
  10.         if ($str[$i] == $str[$M]) { 
  11.             $K[$i] = $K[$i-1] + 1; 
  12.             $M ++; 
  13.         } else { 
  14.             $M = 0; 
  15.             $K[$i] = $K[$M]; 
  16.         } 
  17.     }  //开源软件:phpfensi.com 
  18.     return $K
  19.  
  20. // KMP查找 
  21. function KMPMatch($src$par) { 
  22.     $K = KMP($par); 
  23.  
  24.     $srcLen = strlen($src); 
  25.     $parLen = strlen($par); 
  26.  
  27.     for($i=0,$j=0; $i<$srcLen; ) { 
  28.  
  29.          
  30. //返回完全匹配的位置 
  31.         if ($j == $parLenreturn $i-$j
  32.  
  33.          
  34. //打印匹配过程 
  35.         echo $i."  ".$j" {$src[$i]}-{$par[$j]} <BR>"
  36.  
  37.         if ($par[$j] === $src[$i]) { 
  38.              
  39. //记录匹配个数 
  40.             $j++; 
  41.             $i++; 
  42.         } else { 
  43.             if ($j === 0) { 
  44.                 $i++; 
  45.             } 
  46.             $j = $K[$j-1 >= 0 ? $j -1 : 0]; 
  47.         } 
  48.     } 
  49.     return false; 
  50.  
  51. // 测试下是否可用 
  52. $src = 'BBC ABCDAB ABCDABCDABDE'
  53. $par = 'ABCDABD'
  54.  
  55. // 匹配值 
  56. echo "部分匹配值:", implode(" ", KMP($par)), "<BR>"
  57. // 在给定的字符串中查找特定字符(串) 
  58. echo  KMPMatch($src$par), "<BR>"
  59.  
  60. /* 
  61. 部分匹配值:0 0 0 0 1 2 0 
  62. 0 0 B-A 
  63. 1 0 B-A 
  64. 2 0 C-A 
  65. 3 0  -A 
  66. 4 0 A-A 
  67. 5 1 B-B 
  68. 6 2 C-C 
  69. 7 3 D-D 
  70. 8 4 A-A 
  71. 9 5 B-B 
  72. 10 6 -D 
  73. 10 2 -C 
  74. 10 0 -A 
  75. 11 0 A-A 
  76. 12 1 B-B 
  77. 13 2 C-C 
  78. 14 3 D-D 
  79. 15 4 A-A 
  80. 16 5 B-B 
  81. 17 6 C-D 
  82. 17 2 C-C 
  83. 18 3 D-D 
  84. 19 4 A-A 
  85. 20 5 B-B 
  86. 21 6 D-D 
  87. 15 
  88. */ 
  89. ?>

Tags: php字符串 KMP算法

分享到: