<?php
class Node{
public $value; // 节点值
public $is_end = false; // 是否为结束--是否为某个单词的结束节点
public $childNode = array(); // 子节点
/* 添加孩子节点--注意:可以不为引用函数,因为PHP对象赋值本身就是引用赋值 */
public function &addChildNode($value, $is_end = false){
$node = $this->searchChildNode($value);
if(empty($node)){
// 不存在节点,添加为子节点
$node = new Node();
$node->value = $value;
$this->childNode[] = $node;
}
$node->is_end = $is_end;
return $node;
}
/* 查询子节点 */
public function searchChildNode($value){
foreach ($this->childNode as $k => $v) {
if($v->value == $value){
// 存在节点,返回该节点
return $this->childNode[$k];
}
}
return false;
}
}
/* 添加字符串 */
function addString(&$head, $str){
$node = null;
for ($i=0; $i < strlen($str); $i++) {
if($str[$i] != ' '){
$is_end = $i != (strlen($str) - 1) ? false : true;
if($i == 0){
$node = $head->addChildNode($str[$i], $is_end);
}else{
$node = $node->addChildNode($str[$i], $is_end);
}
}
}
}
/* 获取所有字符串--递归 */
function getChildString($node, $str_array = array(), $str = ''){
if($node->is_end == true){
$str_array[] = $str;
}
if(empty($node->childNode)){
return $str_array;
}else{
foreach ($node->childNode as $k => $v) {
$str_array = getChildString($v, $str_array, $str . $v->value);
}
return $str_array;
}
}
/* 搜索 */
function searchString($node, $str){
for ($i=0; $i < strlen($str); $i++) {
if($str[$i] != ' '){
$node = $node->searchChildNode($str[$i]);
// print_r($node);
if(empty($node)){
// 不存在返回空
return false;
}
}
}
return getChildString($node);
}
/* 调用测试开始 */
$head = new Node; // 树的head
// 添加单词
addString($head, 'hewol');
addString($head, 'hemy');
addString($head, 'heml');
addString($head, 'you');
addString($head, 'yo');
// 获取所有单词
$str_array = getChildString($head);
// 搜索
$search_array = searchString($head, 'hem');
// 循环打印所有搜索结果
foreach ($search_array as $key => $value) {
echo 'hem' . $value . '<br>'; // 输出带上搜索前缀
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有