字符串之模式匹配
PHP代码
<?php /** * @description: 获取模式串在主字符串中的所有首字母出现索引位置(递归版) * @author: cutefrog(injection.mail@gmail.com) * @parameter: $mainstr 主字符串(必要参数) * @parameter: $modestr 模式串(必要参数) * @parameter: $mainpos 主字符串起始索引(可选参数) * @parameter: $modepos 模式串起始索引(可选参数) * @parameter: $matcheds 匹配到的索引数组(不需传入的参数,只作为递归时函数传递参数之用) * @return: $matcheds 如果非空返回匹配到的索引数组,否则返回-1 */ function myStrPos_recursive( $mainstr, $modestr, $mainpos = 0, $modepos = 0, $matcheds = array() ) { //若数组为空则返回-1,否则返回匹配到的数组 if( !isset( $mainstr[$mainpos] ) ) { return empty($matcheds)?-1:$matcheds; } //如果匹配到了就继续与模式串的下一个字符比较 if ( $modestr[$modepos] == $mainstr[$mainpos] ) { if ( !isset($modestr[$modepos+1]) ){ //将匹配结果加入数组 array_push( $matcheds, $mainpos - $modepos ); return myStrPos_recursive ( $mainstr, $modestr, ++$mainpos, 0, $matcheds ); } return myStrPos_recursive ( $mainstr, $modestr, ++$mainpos, ++$modepos, $matcheds ); } //否则回溯主串字符数组索引 else { return myStrPos_recursive ( $mainstr, $modestr, $mainpos-=$modepos-1, 0, $matcheds ); } } /** * @description: 获取模式串在主字符串中的所有首字母出现索引位置(迭代版) * @author: cutefrog(injection.mail@gmail.com) * @parameter: $mainstr 主字符串(必要参数) * @parameter: $modestr 模式串(必要参数) * @return: $matcheds 如果非空返回匹配到的索引数组,否则返回-1 */ function myStrPos_iteration( $mainstr, $modestr ) { $mainlen = strlen( $mainstr ); $modelen = strlen( $modestr ); $matchedpos = -1; $limit = 0; $matcheds = array(); for ( $mainpos = 0; $mainpos < $mainlen; $mainpos++ ){ for ( $modepos = 0; $modepos < $modelen; $modepos++ ) if ( $modestr[$modepos] == $mainstr[$mainpos] ){ if ( $modepos == ( $modelen - 1 ) ){ $matcheds[$limit++] = $mainpos - $modepos; break; } $mainpos++; } else { $mainpos = $mainpos - $modepos; break; } } return empty($matcheds)?-1:$matcheds; } $mainstr = 'dccabsccadsacca'; $modestr = 'cca'; print_r( myStrPos_recursive( $mainstr, $modestr ) ); print_r( myStrPos_iteration( $mainstr, $modestr ) ); ?>
Copy after login
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article
Repo: How To Revive Teammates
1 months ago
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago
By 尊渡假赌尊渡假赌尊渡假赌
How Long Does It Take To Beat Split Fiction?
4 weeks ago
By DDD
R.E.P.O. Save File Location: Where Is It & How to Protect It?
4 weeks ago
By DDD

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)
