php字符串字符处理函数详解,php中字符串匹配K

作者: 金沙澳门官网  发布:2019-09-26

kmp算法是一种立异的字符串相称算法,由D.E.Knuth与V.智跑.Pratt和J.H.Morris同有时候开掘,因而群众称它为克努特——Maurice——普拉特操作(简称KMP算法)。KMP算法的入眼是依附给定的方式串W1,m,定义多少个next函数。next函数包涵了方式串本人局地相称的音信

以下是代码片段:

例子

 代码如下

 代码如下

<?   

<?php
/*

//--------------------   

字符串匹配KMP算法的PHP语言完毕

// 基本数据结构算法  

*/

//--------------------   

function KMP($str) {
    $K = array(0);
    $M = 0;
    $strLen = strlen($str);
    for($i=1; $i<$strLen; $i++) {
        if ($str[$i] == $str[$M]) {
            $K[$i] = $K[$i-1] + 1;
            $M ++;
        } else {
            $M = 0;
            $K[$i] = $K[$M];
        }
    }
    return $K;
}
 
// KMP查找

//二分查找(数组里搜索某些元素)   

function KMPMatch($src, $par) {
    $K = KMP($par);
 
    $srcLen = strlen($src);
    $parLen = strlen($par);
 
    for($i=0,$j=0; $i<$srcLen; ) {
 
        
//重回完全相称的岗位

function bin_sch($array,  $low, $high, $k){    

        if ($j == $parLen) return $i-$j;
 
        
//打字与印刷相称进程

    if ( $low <= $high){    

        echo $i."  ".$j. " {$src[$i]}-{$par[$j]} <BR>";
 
        if ($par[$j] === $src[$i]) {
            
//记录匹配个数

        $mid =  intval(($low+$high)/2 );    

            $j++;
            $i++;
        } else {
            if ($j === 0) {
                $i++;
            }
            $j = $K[$j-1 >= 0 ? $j -1 : 0];
        }
    }
    return false;
}
 
// 测量试验下是否可用

        if ($array[$mid] ==  $k){    

$src = 'BBC ABCDAB ABCDABCDABDE';
$par = 'ABCDABD';
 
// 匹配值

            return $mid;    

echo "部分相配值:", implode(" ", KMP($par)), "<B冠道>";
// 在加以的字符串中寻觅特定字符(串)

        }elseif ( $k < $array[$mid]){    

echo  KMPMatch($src, $par), "<BR>";
 
/*

            return  bin_sch($array, $low,  $mid-1, $k);    

某些相配值:0 0 0 0 1 2 0

        }else{    

0 0 B-A

            return  bin_sch($array, $mid+ 1, $high, $k);    

1 0 B-A

        }    

2 0 C-A

    }    

3 0  -A

    return -1;    

4 0 A-A

}    

5 1 B-B

//顺序查找(数组里寻觅某个成分)   

6 2 C-C

function  seq_sch($array, $n,  $k){    

7 3 D-D

    $array[$n] =  $k;    

8 4 A-A

    for($i=0;  $i<$n; $i++){    

9 5 B-B

        if( $array[$i]==$k){    

10 6 -D

            break;    

10 2 -C

        }    

10 0 -A

    }    

11 0 A-A

    if ($i<$n){    

12 1 B-B

        return  $i;    

13 2 C-C

    }else{    

14 3 D-D

        return -1;    

15 4 A-A

    }    

16 5 B-B

}    

17 6 C-D

//线性表的去除(数组中贯彻)   

17 2 C-C

function delete_array_element($array , $i)   

18 3 D-D

{   

19 4 A-A

        $len =  count($array);    

20 5 B-B

        for ($j= $i; $j<$len; $j ++){   

21 6 D-D

                $array[$j] = $array [$j+1];   

15

        }   

*/

        array_pop ($array);   

        return $array ;   

}   

//冒泡排序(数组排序)   

function bubble_sort( $array)   

{   

        $count = count( $array);   

        if ($count <= 0 ) return false;   

        for($i=0 ; $i<$count; $i ++){   

                for($j=$count-1 ; $j>$i; $j--){   

                        if ($array[$j] < $array [$j-1]){   

                                 $tmp = $array[$j];   

                                 $array[$j] = $array[ $j-1];   

                                $array [$j-1] = $tmp;   

                        }   

                }   

        }   

        return $array;   

}   

//快捷排序(数组排序)   

function quick_sort($array ) {   

        if (count($array) <= 1) return  $array;   

        $key = $array [0];   

        $left_arr  = array();   

        $right_arr = array();   

        for ($i= 1; $i<count($array ); $i++){   

                if ($array[ $i] <= $key)   

                        $left_arr [] = $array[$i];   

                else  

                         $right_arr[] = $array[$i ];   

        }   

        $left_arr = quick_sort($left_arr );   

        $right_arr = quick_sort( $right_arr);   

        return array_merge($left_arr , array($key), $right_arr);   

}   

  

//------------------------   

// PHP内置字符串函数完成   

//------------------------   

//字符串长度   

function strlen ($str)   

{   

        if ($str == '' ) return 0;   

        $count =  0;   

        while (1){   

                if ( $str[$count] != NULL){   

                         $count++;   

                        continue;   

                }else{   

                        break;   

                }   

        }   

        return $count;   

}   

//截取子串   

function substr($str, $start,  $length=NULL)   

{   

        if ($str== '' || $start>strlen($str )) return;   

        if (($length!=NULL) && ( $start>0) && ($length> strlen($str)-$start)) return;   

        if (( $length!=NULL) && ($start< 0) && ($length>strlen($str )+$start)) return;   

        if ($length ==  NULL) $length = (strlen($str ) - $start);   

            

        if ($start <  0){   

                for ($i=(strlen( $str)+$start); $i<(strlen ($str)+$start+$length ); $i++) {   

                        $substr .=  $str[$i];   

                }   

        }   

        if ($length  > 0){   

                for ($i= $start; $i<($start+$length ); $i++) {   

                        $substr  .= $str[$i];   

                }   

        }   

        if ( $length < 0){   

                for ($i =$start; $i<(strlen( $str)+$length); $i++) {   

                        $substr .= $str[$i ];   

                }   

        }   

        return $substr;   

}   

//字符串翻转   

function strrev($str)   

{   

        if ($str == '') return 0 ;   

        for ($i=(strlen($str)- 1); $i>=0; $i --){   

                $rev_str .= $str[$i ];   

        }   

        return $rev_str;   

}   

  

//字符串比较   

function strcmp($s1,  $s2)   

{   

        if (strlen($s1) <  strlen($s2)) return -1 ;   

        if (strlen($s1) > strlen( $s2)) return 1;   

        for ($i =0; $i<strlen($s1 ); $i++){   

                if ($s1[ $i] == $s2[$i]){   

                        continue;   

                }else{   

                        return false;   

                }   

        }   

        return  0;   

}   

  

//查找字符串   

function  strstr($str, $substr)   

{   

         $m = strlen($str);   

        $n = strlen($substr );   

        if ($m < $n) return false ;   

        for ($i=0; $i <=($m-$n+1); $i ++){   

                $sub = substr( $str, $i, $n);   

                if ( strcmp($sub, $substr) ==  0)  return $i;   

        }   

        return false ;   

}   

//字符串替换   

function str_replace($substr , $newsubstr, $str)   

{   

         $m = strlen($str);   

        $n = strlen($substr );   

        $x = strlen($newsubstr );   

        if (strchr($str, $substr ) == false) return false;   

        for ( $i=0; $i<=($m- $n+1); $i++){   

                 $i = strchr($str,  $substr);   

                $str = str_delete ($str, $i, $n);   

                $str = str_insert($str,  $i, $newstr);   

        }   

        return $str ;   

}   

  

//--------------------   

// 自完成字符串管理函数  

//--------------------   

//插入一段字符串   

function str_insert($str, $i , $substr)   

{   

        for($j=0 ; $j<$i; $j ++){   

                $startstr .= $str[$j ];   

        }   

        for ($j=$i; $j <strlen($str); $j ++){   

                $laststr .= $str[$j ];   

        }   

        $str = ($startstr . $substr  . $laststr);   

        return $str ;   

}   

//删除一段字符串   

function str_delete($str , $i, $j)   

{   

        for ( $c=0; $c<$i;  $c++){   

                $startstr .= $str [$c];   

        }   

        for ($c=( $i+$j); $c<strlen ($str); $c++){   

                $laststr  .= $str[$c];   

        }   

         $str = ($startstr . $laststr );   

        return $str;   

}   

//复制字符串   

function strcpy($s1, $s2 )   

{   

        if (strlen($s1)==NULL || !isset( $s2)) return;   

        for ($i=0 ; $i<strlen($s1);  $i++){   

                $s2[] = $s1 [$i];   

        }   

        return $s2;   

}   

//连接字符串   

function strcat($s1 , $s2)   

{   

        if (!isset($s1) || !isset( $s2)) return;   

        $newstr = $s1 ;   

        for($i=0; $i <count($s); $i ++){   

                $newstr .= $st[$i ];   

        }   

        return $newsstr;   

}   

//简单编码函数(与php_decode函数对应)   

function php_encode($str)   

{   

        if ( $str=='' && strlen( $str)>128) return false;   

        for( $i=0; $i<strlen ($str); $i++){   

                 $c = ord($str[$i ]);   

                if ($c>31 && $c <107) $c += 20 ;   

                if ($c>106 && $c <127) $c -= 75 ;   

                $word = chr($c );   

                $s .= $word;   

        }    

        return $s;    

}   

//轻易解码函数(与php_encode函数对应)   

function php_decode($str)   

{   

        if ( $str=='' && strlen($str )>128) return false;   

        for( $i=0; $i<strlen ($str); $i++){   

                $c  = ord($word);   

                if ( $c>106 && $c<127 ) $c = $c-20;   

                if ($c>31 && $c< 107) $c = $c+75 ;   

                $word = chr( $c);   

                $s .= $word ;   

        }    

        return $s;    

}   

//轻巧加密函数(与php_decrypt函数对应)   

function php_encrypt($str)   

{   

         $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';   

         $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';   

        if ( strlen($str) == 0) return  false;   

        for ($i=0;  $i<strlen($str); $i ++){   

                for ($j=0; $j <strlen($encrypt_key); $j ++){   

                        if ($str[$i] == $encrypt_key [$j]){   

                                $enstr .=  $decrypt_key[$j];   

                                break;   

                        }   

                }   

        }   

        return $enstr;   

}   

//简单解密函数(与php_encrypt函数对应)   

function php_decrypt($str)   

{   

         $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';   

         $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';   

        if ( strlen($str) == 0) return  false;   

        for ($i=0;  $i<strlen($str); $i ++){   

                for ($j=0; $j <strlen($decrypt_key); $j ++){   

                        if ($str[$i] == $decrypt_key [$j]){   

                                $enstr .=  $encrypt_key[$j];   

                                break;   

                        }   

                }   

        }   

        return $enstr;   

}   

?>  

php字符串管理函数大全
addcslashes — 为字符串里面包车型客车一些字符增加反斜线转义字符
addslashes — 用钦赐的措施对字符串里面的字符举办转义
bin2hex — 将二进制数据调换来十六进制表示
chop — rtrim() 的外号函数
chr — 重回贰个字符的ASCII码
chunk_split — 按一定的字符长度将字符串分割成小块
convert_cyr_string — 将斯拉夫语字符调换为别的字符
convert_uudecode — 解密一个字符串
convert_uuencode — 加密二个字符串
count_chars — 重返二个字符串里面包车型大巴字符使用音讯
crc32 — 总括叁个字符串的crc32多项式
crypt — 单向散列加密函数
echo — 用以显示一些内容
explode — 将二个字符串用分割符转变为一数组格局
fprintf — 遵照要求对数码进行重返,并直接写入文档流
get_html_translation_table — 重回能够调换的HTML实体
hebrev — 将Hebrew编码的字符串调换为可视的文书
hebrevc — 将Hebrew编码的字符串调换为可视的文件
html_entity_decode — htmlentities ()函数的反函数,将HTML实体转变为字符
htmlentities — 将字符串中有些字符调换为HTML实体
htmlspecialchars_decode —htmlspecialchars()函数的反函数,将HTML实体调换为字符
htmlspecialchars — 将字符串中有的字符转变为HTML实体
implode — 将数组用特定的分割符转换为字符串
join — 将数组转换为字符串,implode()函数的别称
levenshtein — 计算四个词的差距大小
localeconv — 获取数字相关的格式定义
ltrim — 去除字符串侧边包车型客车空域也许钦点的字符
md5_file — 将二个文本实行MD5算法加密
md5 — 将三个字符串进行MD5算法加密
metaphone — 决断三个字符串的失声准则
money_format — 依据参数对数字进行格式化的输出
nl_langinfo — 查询语言和地面新闻
nl2br — 将字符串中的换行符“n”替换到“<br/>”
number_format — 依据参数对数字举办格式化的出口
ord — 将多少个ASCII码调换为贰个字符
parse_str — 把自然格式的字符串调换为变量和值
print — 用以输出贰个独立的值
printf — 依照供给对数码开展体现
quoted_printable_decode — 将二个字符串加密为多少个8位的二进制字符串
quotemeta — 对若干个特定字符实行转义
rtrim — 去除字符串右边的空域也许内定的字符
setlocale — 设置关于数字,日期等等的本地格式
sha1_file — 将三个文书举行SHA1算法加密
sha1 — 将三个字符串进行SHA1算法加密
similar_text — 相比五个字符串,再次回到系统以为的貌似字符个数
soundex — 判断二个字符串的失声法则
sprintf — 根据须求对数据开展重临,可是不出口
sscanf — 能够对字符串进行格式化
str_ireplace — 像str_replace()函数同样相配和替换字符串,然而不区分轻重缓急写
str_pad — 对字符串进行两边的补白
str_repeat — 对字符串实行重复组合
str_replace — 相称和替换字符串
str_rot13 — 将字符串进行ROT13加密管理
str_shuffle — 对八个字符串里面包车型客车字符实行自由排序
str_split — 将一个字符串依照字符间距分割为贰个数组
str_word_count — 得到字符串里面包车型地铁克罗地亚共和国语单词音讯
strcasecmp — 对字符串举办高低相比较,不区分轻重缓急写
strchr — 通过比较重回八个字符串的有个别strstr()函数的别称
strcmp — 对字符串实行高低相比较
strcoll – 分公司面设置对字符串举办高低比较
strcspn — 重回字符一连非相配长度的值
strip_tags — 去除二个字符串里面包车型客车HTML和PHP代码
stripcslashes — 反转义addcslashes()函数转义管理过的字符串
stripos — 查找并赶回第多个相称项的岗位,相配不区分轻重缓急写
stripslashes — 反转义addslashes()函数转义管理过的字符串
stristr — 通过相比再次回到一个字符串的部分,相比较时不区分轻重缓急写
strlen — 获取二个字符串的编码长度
strnatcasecmp — 使用当然排序法对字符串实行高低相比,不区分轻重缓急写
strnatcmp — 使用当然排序法对字符串实行高低相比较
strncasecmp — 对字符串的前N个字符进行高低相比较,不区分轻重缓急写
strncmp — 对字符串的前N个字符进行高低相比
strpbrk — 通过相比再次回到贰个字符串的有的
strpos — 查找并赶回第三个相配项的地方
strrchr — 通过从后往前比较再次来到多少个字符串的部分
strrev — 将字符串里面包车型地铁装有字母反向排列
strripos — 从后往前找出并赶回第2个相称项的岗位,般配不区分轻重缓急写
strrpos – 从后往前搜索并回到第四个相称项的岗位
strspn — 匹配并回到字符三番五次出现长短的值
strstr — 通过比较重返贰个字符串的一些
strtok — 用内定的繁多少个字符来分割字符串
strtolower — 将字符串调换为题写
strtoupper –将字符串转变为题写
strtr — 对字符串相比较替换
substr_compare — 对字符串进行截取后的比较
substr_count — 总计字符串中某字符段的产出次数
substr_replace — 对字符串中的部分字符实行轮换
substr — 对字符串实行截取
trim — 去除字符串两侧的空白也许钦命的字符
ucfirst — 将所给字符串的率先个假名转变为题写
ucwords — 将所给字符串的每二个保扩张哥洛美语单词的第三个字母形成大写
vfprintf — 依照供给对数据开展重回,并直接写入文档流
vprintf — 依据供给对数码实行显示
vsprintf — 遵照供给对数据开展再次来到,然而不出口
wordwrap — 遵照一定的字符长度分割字符串

本文由金沙澳门官网送注册58发布于金沙澳门官网,转载请注明出处:php字符串字符处理函数详解,php中字符串匹配K

关键词:

上一篇:没有了
下一篇:文件重命名rename函数用法,修改时间