PHP字典树(Trie树)定义与实现方法示例

yizhihongxing

PHP字典树(Trie树)定义与实现方法示例

定义

Trie树,也叫字典树或者单词查找树,是一种树形数据结构,常用于统计或者排序字符串数据集。它能够高效地支持字符串数据的插入、查找和前缀搜索等操作,时间复杂度与字符串长度有关,对于一定量的字符串集合,它的查找效率比哈希表更高。

Trie树与二叉查找树最大的不同在于,Trie树每个节点不仅仅存储一个关键码,而是存储一个关键码序列。Trie树的核心思想是利用字符串之间的公共前缀,将重复的前缀合并在一起,从而减少了存储空间,提高了查找效率。

实现

定义类

我们定义一个Trie树类TrieTree,它有以下三个属性:

  • $root:根节点,初始时为空;
  • $count:Trie树中单词的数量,初始为0;
  • $size:Trie树中节点的数量,初始为1(根节点)。
class TrieTree {
    private $root;
    private $count;
    private $size;

    public function __construct() {
        $this->root = new TrieNode();
        $this->count = 0;
        $this->size = 1;
    }
}

定义节点类

我们定义Trie树中的节点类TrieNode,它有以下三个属性:

  • $char:该节点存储的字符;
  • $isEnd:是否为单词结尾,初始为false;
  • $children:该节点的子节点,初始为空数组。
class TrieNode {
    public $char;
    public $isEnd;
    public $children;

    public function __construct($char = null) {
        $this->char = $char;
        $this->isEnd = false;
        $this->children = [];
    }
}

插入单词操作

Trie树的插入操作需要遍历整个单词,然后将单词的每个字符依次插入到Trie树中。

public function insert($word) {
    $node = $this->root;
    for ($i = 0; $i < strlen($word); $i++) {
        $char = $word[$i];
        if (!isset($node->children[$char])) {
            $node->children[$char] = new TrieNode($char);
            $this->size++;
        }
        $node = $node->children[$char];
    }
    if (!$node->isEnd) {
        $node->isEnd = true;
        $this->count++;
    }
}

查找单词操作

Trie树的查找操作需要遍历整个单词,然后判断每个字符是否存在于Trie树中。

public function search($word) {
    $node = $this->root;
    for ($i = 0; $i < strlen($word); $i++) {
        $char = $word[$i];
        if (!isset($node->children[$char])) {
            return false;
        }
        $node = $node->children[$char];
    }
    return $node->isEnd;
}

查找前缀操作

Trie树的查找前缀操作需要遍历前缀,然后判断每个字符是否存在于Trie树中。

public function startsWith($prefix) {
    $node = $this->root;
    for ($i = 0; $i < strlen($prefix); $i++) {
        $char = $prefix[$i];
        if (!isset($node->children[$char])) {
            return false;
        }
        $node = $node->children[$char];
    }
    return true;
}

示例

示例1:插入单词和查找单词操作

我们创建一个Trie树对象,插入若干个单词,然后查找某些单词是否存在。

$trie = new TrieTree();
$trie->insert('apple');
$trie->insert('banana');
$trie->insert('orange');
$trie->insert('pear');

echo $trie->search('apple'); // true
echo $trie->search('pear'); // true
echo $trie->search('watermelon'); // false

示例2:查找前缀操作

我们创建一个Trie树对象,插入一些单词,然后查找以某个前缀开头的单词个数。

$trie = new TrieTree();
$trie->insert('apple');
$trie->insert('banana');
$trie->insert('orange');
$trie->insert('pear');

echo $trie->startsWith('a'); // true
echo $trie->startsWith('ab'); // false
echo $trie->startsWith('pe'); // true

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:PHP字典树(Trie树)定义与实现方法示例 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • 使用phpQuery获取数组的实例

    获取数组是PHP开发中非常常见的操作。本文将详细讲解如何使用phpQuery获取数组。 准备工作 在使用phpQuery获取数组之前,需要先安装phpQuery。可以通过官方网站进行下载和安装。 使用phpQuery获取数组 示例一:获取网页中所有链接 下面是获取网页中所有链接的代码示例: require_once(‘phpQuery/phpQuery.ph…

    PHP 2023年5月26日
    00
  • 8个必备的PHP功能实例代码

    下面我将详细讲解“8个必备的PHP功能实例代码”的完整攻略。 一、什么是“8个必备的PHP功能实例代码” “8个必备的PHP功能实例代码”是一个包含8个PHP功能实例代码的集合。这个集合将帮助PHP开发者提高其编程技能并增进对PHP的深入理解。这它包括了以下8个功能示例: 通过邮件发送表单数据 解析xml文件 上传文件 下载文件 分页 图片轮播 列表排序 统…

    PHP 2023年5月23日
    00
  • 小程序兼容安卓和IOS数据处理问题及坑

    小程序在处理数据时,需要考虑兼容安卓和iOS两个平台,因为它们的底层系统和部分API存在一定差异,如果不注意兼容性问题,就会导致程序在某一平台上出现异常或者崩溃,给用户带来极差的体验。 下面是一些小程序兼容安卓和iOS数据处理问题及解决方法的攻略: 1. 字符串拼接问题 在字符串拼接时,如果使用 + 运算符进行拼接,有时会出现异常。这是因为,在安卓平台上,如…

    PHP 2023年5月30日
    00
  • 深入浅出php socket编程

    深入浅出php socket编程 概述 PHP作为一种Web开发语言,其强大的功能和高效的性能越来越受到开发人员的青睐。而socket编程则是网络编程中的基础,掌握socket编程,可以让我们更好地理解网络编程和Web开发。 在本文中,我们将深入浅出地介绍PHP socket编程的基础知识和技术,包括socket的基本概念、如何创建socket、如何使用so…

    PHP 2023年5月23日
    00
  • PHP $_FILES函数详解

    PHP $_FILES函数详解 PHP中的$_FILES函数用于从上传的文件中获取信息。它可以让我们访问上传文件的名称、类型、大小、临时文件名和编码等信息。 上传文件表单 要用$_FILES函数处理上传的文件,我们需要先在HTML表单中添加一个”file”类型的表单元素,使用户可以将文件选择其中并上传到我们的服务器: <form action=&quo…

    PHP 2023年5月26日
    00
  • PHP微商城开源代码实例

    下面我将详细介绍“PHP微商城开源代码实例”的完整攻略。 一、背景介绍 “PHP微商城开源代码实例”是一种基于PHP语言的微信公众号商城系统,它可以帮助用户快速搭建自己的微商城,并且提供了完整的后台管理功能。系统代码全部开源,可以自由定制和修改。 二、系统安装与配置 1. 环境要求 首先,我们需要在部署环境上,确保系统运行的正常。本系统需要以下环境: PHP…

    PHP 2023年5月24日
    00
  • 详解PHP中数组函数的知识点

    以下是“详解PHP中数组函数的知识点”的完整使用攻略,包括数组函数的基本概念、常见函数和示例说明等内容。 数组函数基本概念 数组是一种常见的数据类型,它可以存储多个值,并通过索引访问这些值。在PHP中,数组函数可以帮助程序对数组进行操作和处理,例如添加、删除、排序等。 常见函数 以下是PHP中常见的数组函数: 1. 添加元素 array_push array…

    PHP 2023年5月12日
    00
  • php简单判断两个字符串是否相等的方法

    当我们需要在php中判断两个字符串是否相等时,一般可以使用“==”或“===”运算符进行判断。其中“==”运算符是比较两个字符串值是否相同,而“===”运算符不仅要求值相同,还要求值的类型也相同。 下面我们来演示一下“==”和“===”运算符的使用: 示例1:使用“==”运算符比较两个字符串是否相等 $str1 = "hello"; $s…

    PHP 2023年5月26日
    00
合作推广
合作推广
分享本页
返回顶部