本文实例讲述了PHP实现的字符串匹配算法————sunday算法。分享给大家供大家参考,具体如下:
Sunday算法是Daniel M.Sunday于1990年提出的字符串模式匹配。其核心思想是:在匹配过程中,模式串发现不匹配时,算法能跳过尽可能多的字符以进行下一步的匹配,从而提高了匹配效率。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
<?php
/*
*@param $pattern 模式串
*@param $text 待匹配串
*/
function mySunday( $pattern = '' , $text = '' ){
if (! $pattern || ! $text ) return false;
$pattern_len = mb_strlen( $pattern );
$text_len = mb_strlen( $text );
if ( $pattern_len >= $text_len ) return false;
$i = 0;
for ( $i = 0; $i < $pattern_len ; $i ++){ //组装以pattern中的字符为下标的数组
$shift [ $pattern [ $i ]] = $pattern_len - $i ;
}
while ( $i <= $text_len - $pattern_len ){
$nums = 0; //匹配上的字符个数
while ( $pattern [ $nums ] == $text [ $i + $nums ]){
$nums ++;
if ( $nums == $pattern_len ){
return "The first match index is $i\n" ;
}
}
if ( $i + $pattern_len < $text_len && isset( $shift [ $text [ $i + $pattern_len ]])){ //判断模式串后一位字符是否在模式串中
$i += $shift [ $text [ $i + $pattern_len ]]; //对齐该字符
} else {
$i += $pattern_len ; //直接滑动pattern_len位
}
}
}
$text = "I am testing mySunday on sunday!" ;
$pattern = "sunday" ;
echo mySunday( $pattern , $text );
|
运行结果:
1
|
The first match index is 25
|
希望本文所述对大家PHP程序设计有所帮助。
原文链接:http://blog.csdn.net/fff058/article/details/52204233